CROSS-REFERENCE TO RELATED APPLICATIONS
The present application is a continuation of U.S. patent application Ser. No. 18/310,040, titled “SYSTEMS, METHODS, AND APPARATUS FOR ENHANCED HEADSETS” and filed May 1, 2023, which was a continuation of U.S. patent application Ser. No. 17/478,021, titled “SYSTEMS, METHODS, AND APPARATUS FOR ENHANCED HEADSETS” and filed Sep. 17, 2021, which was a continuation of U.S. patent application Ser. No. 17/320,164, titled “SYSTEMS, METHODS, AND APPARATUS FOR ENHANCED HEADSETS” and filed May 13, 2021, which was a Non-Provisional of, and claimed benefit and priority to, U.S. Provisional Patent Application No. 63/023,965, titled “SYSTEMS, METHODS, AND APPARATUS FOR ENHANCED HEADSETS” and filed May 13, 2020 in the name of Jorasch et al., the entirety of which are hereby incorporated by reference herein for all purposes.
COPYRIGHT NOTICE
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
BACKGROUND
People use headsets for listening to music and for providing data to computers for enabling communications. For example, headsets are commonly used to enhance the audio quality of video calls, such as business meetings, online classes, or video game team communications.
SUMMARY
Various embodiments comprise systems, methods, and apparatus for enhancing headsets with additional capabilities. Various embodiments enable an integration of data from many sources and enable intelligent processing of that data such that many elements of the system can be optimized and enhanced. In addition to enhancing online calls, game experiences, and the consumption of music and audio files, the various embodiments also address the need to enhance the use of business software applications, safety protocols, authentication, gameplay experiences, recreational activities, social interactions, and educational activities.
An understanding of embodiments described herein and many of the attendant advantages thereof may be readily obtained by reference to the following detailed description when considered with the accompanying drawings, wherein:
DETAILED DESCRIPTION
Embodiments described herein are descriptive of systems, apparatus, methods, interfaces, and articles of manufacture for utilizing devices and/or for managing meetings.
Headings, section headings, and the like are used herein for convenience and/or to comply with drafting traditions or requirements. However, headings are not intended to be limiting in any way. Subject matter described within a section may encompass areas that fall outside of or beyond what might be suggested by a section heading; nevertheless, such subject matter is not to be limited in any way by the wording of the heading, nor by the presence of the heading. For example, if a heading says “Mouse Outputs”, then outputs described in the following section may apply not only to computer mice, but to other peripheral devices as well.
As used herein, a “user” may include a human being, set of human beings, group of human beings, an organization, company, legal entity, or the like. A user may be a contributor to, beneficiary of, agent of, and/or party to embodiments described herein. For example, in some embodiments, a user's actions may result in the user receiving a benefit.
In various embodiments, the term “user” may be used interchangeably with “employee”, “attendee”, or other party to which embodiments are directed.
A user may own, operate, or otherwise be associated with a computing device, such as a personal computer, desktop, Apple Macintosh, or the like, and such device may be referred to herein as “user device”. A user device may be associated with one or more additional devices. Such additional devices may have specialized functionality, such as for receiving inputs or providing outputs to users. Such devices may include computer mice, keyboards, headsets, microphones, cameras, and so on, and such devices may be referred to herein as “peripheral devices”. In various embodiments, a peripheral device may exist even if it is not associated with any particular user device. In various embodiments, a peripheral device may exist even if it is not associated with any particular other device.
As used herein, a “skin” may refer to an appearance of an outward-facing surface of a device, such as a peripheral device. The surface may include one or more active elements, such as lights, LEDs, display screens, electronic ink, e-skin, or any other active elements. In any case, the surface may be capable of changing its appearance, such as by changing its color, changing its brightness, changing a displayed image, or making any other change. When the outward service of a device changes its appearance, the entire device may appear to change its appearance. In such cases, it may be said that the device has taken on a new “skin”.
As used herein, pronouns are not intended to be gender-specific unless otherwise specified or implied by context. For example, the pronouns “he”, “his”, “she”, and “her” may refer to either a male or a female.
As used herein, a “mouse-keyboard” refers to a mouse and/or a keyboard, and may include a device that has the functionality of mouse, a device that has the functionality of a keyboard, a device that has some functionality of a mouse and some functionality Of a keyboard and/or a device that has the functionality of both a mouse and a keyboard.
Systems
Referring first to
Various components of system 100 may communicate with one another via one or more networks (e.g., via network 104). Such networks may comprise, for example, a mobile network such as a cellular, satellite, or pager network, the Internet, a wide area network, a Wi-Fi® network, another network, or a combination of such networks. For example, in one embodiment, both a wireless cellular network and a Wi-Fi® network may be involved in routing communications and/or transmitting data among two or more devices or components. The communication between any of the components of system 100 (or of any other system described herein) may take place over one or more of the following: the Internet, wireless data networks, such as 802.11 Wi-Fi®, PSTN interfaces, cable modem DOCSIS data networks, or mobile phone data networks commonly referred to as 3G, LTE, LTE—advanced, etc.
In some embodiments, additional devices or components that are not shown in
Thus, a third party server may be a part of a system such as that illustrated in
It should be understood that any of the functionality described herein as being performed by a particular component of the system 100 may in some embodiments be performed by another component of the system 100 and/or such a third party server. For example, one or more of the functions or processes described herein as being performed by the central controller 110 (e.g., by a module or software application of the central controller) or another component of system 100 may be implemented with the use of one or more cloud-based servers which, in one embodiment, may be operated by or with the help of a third party distinct from the central controller 110. In other words, while in some embodiments the system 100 may be implemented on servers that are maintained by or on behalf of central controller 110, in other embodiments it may at least partially be implemented using other arrangements, such as in a cloud-computing environment, for example.
In various embodiments, peripheral devices 107b and 107c may be in communication with user device 106b, such as by wired connection (e.g., via USB cable), via wireless connection (e.g., via Bluetooth®) or via any other connection means. In various embodiments, peripheral devices 107b and 107c may be in communication with one another via user device 106b (e.g., using device 106b as an intermediary). In various embodiments, peripheral device 107d may be in communication with peripheral device 107c, such as by wired, wireless, or any other connection means. Peripheral device 107d may be in communication with peripheral device 107b via peripheral device 107c and user device 106b (e.g., using devices 107c and 106b as intermediaries). In various embodiments, peripheral devices 107b and/or 107c may be in communication with network 104 via user device 106b (e.g., using device 106b as an intermediary). Peripheral devices 107b and/or 107c may thereby communicate with other devices (e.g., peripheral device 107p or central controller 110) via the network 104. Similarly, peripheral device 107d may be in communication with network 104 via peripheral device 107c and user device 106b (e.g., by using both 107c and 106b as intermediaries). In various embodiments, peripheral device 107d may thereby communicate with other devices via the network 104.
In various embodiments, local network 109 is in communication with network 104. Local network 109 may be, for example, a Local Area Network (LAN), Wi-Fi® network, Ethernet-based network, home network, school network, office network, business network, or any other network. User device 106a and peripheral devices 107e-n may each be in communication with local network 109. Devices 106a and 107e-n may communicate with one another via local network 109. In various embodiments, one or more of devices 106a and 107e-n may communicate with other devices (e.g., peripheral device 107p or central controller 110) via both the local network 109 network 104. It will be appreciated that the depicted devices 106a and 107e-n are illustrative of some embodiments, and that various embodiments contemplate more or fewer user devices and/or more or fewer peripheral devices in communication with local network 109.
It will be appreciated that various embodiments contemplate more or fewer user devices than the depicted user devices 106a-n. Various embodiments contemplate fewer or more local networks, such as local network 109. In various embodiments, each local network may be in communication with a respective number of user devices and/or peripherals. Various embodiments contemplate more or fewer peripheral devices than the depicted peripheral devices 107a-n and 107p-z. Various embodiments contemplate more or fewer resource devices than the depicted resource devices 102a-n. Various embodiments contemplate more or fewer third-party devices than the depicted third-party device 108. In a similar vein, it will be understood that ranges of reference numerals, such as “102a-n”, do not imply that there is exactly one such device corresponding to each alphabet letter in the range (e.g., in the range “a-n”). Indeed, there may be more or fewer such devices than the number of alphabet letters in the indicated range.
In various embodiments, resource devices 102a-n may include devices that store data and/or provide one or more services used in various embodiments. Resource devices 102a-n may be separate from the central controller 110. For example, a resource device may belong to a separate entity to that of the central controller. In various embodiments, one or more resource devices are part of the central controller, have common ownership with the central controller, or are otherwise related to the central control. In various embodiments, resource devices 102a-n may include one or more databases, cloud computing and storage services, calling platforms, video conferencing platforms, streaming services, voice over IP services, authenticating services, certificate services, cryptographic services, anonymization services, biometric analysis services, transaction processing services, financial transaction processing services, digital currency transaction services, file storage services, document storage services, translation services, transcription services, providers of imagery, image/video processing services, providers of satellite imagery, libraries for digital videos, libraries for digital music, library for digital lectures, libraries for educational content, libraries for digital content, providers of shared workspaces, providers of collaborative workspaces, online gaming platforms, game servers, advertisem*nt aggregation services, advertisem*nt distribution services, facilitators of online meetings, email servers, messaging platforms, Wiki hosts, website hosts, providers of software, providers of software-as-a-service, providers of data, providers of user data, and/or any other data storage device and/or any other service provider.
For example, a resource device (e.g., device 102a), may assist the central controller 110 in authenticating a user every time the user logs into a video game platform associated with the central controller. As another example, a resource device may store digital music files that are downloaded to a user device as a reward for the user's performance in a video game associated with the central controller. As another example, a resource device may provide architectural design software for use by users designing a building in a shared workspace associated with the central controller. According to some embodiments, communications between and/or within the devices 102a-n, 106a-n, 107a-n and 107p-z, 108, and 110 of the system 100 may be utilized to (i) conduct a multiplayer game, (ii) conduct a meeting, (iii) facilitate a collaborative project, (iv) distribute advertisem*nts, (v) provide teaching, (vi) provide evaluations and ratings or individuals or teams, (vii) facilitate video conferencing services, (viii) enhance educational experiences, and/or for any other purpose.
Fewer or more components 102a-n, 104, 106a-n, 107a-n, 107p-z, 108, 110 and/or various configurations of the depicted components 102a-n, 104, 106a-n, 107a-n, 107p-z, 108, 110 may be included in the system 100 without deviating from the scope of embodiments described herein. In some embodiments, the components 102a-n, 104, 106a-n, 107a-n, 107p-z, 108, 110 may be similar in configuration and/or functionality to similarly named and/or numbered components as described herein. In some embodiments, the system 100 (and/or portion thereof) may comprise a platform programmed and/or otherwise configured to execute, conduct, and/or facilitate the methods (e.g., 7900 of
According to some embodiments, the resource devices 102a-n and/or the user devices 106a-n may comprise any type or configuration of computing, mobile electronic, network, user, and/or communication devices that are or become known or practicable. The resource devices 102a-n and/or the user devices 106a-n may, for example, comprise one or more Personal Computer (PC) devices, computer workstations, server computers, cloud computing resources, video gaming devices, tablet computers, such as an iPad® manufactured by Apple®, Inc. of Cupertino, CA, and/or cellular and/or wireless telephones, such as an iPhone® (also manufactured by Apple®, Inc.) or an LG V50 THINQ™ 5G smart phone manufactured by LG® Electronics, Inc. of San Diego, CA, and running the Android® operating system from Google®, Inc. of Mountain View, CA. In some embodiments, the resource devices 102a-n and/or the user devices 106a-n may comprise one or more devices owned and/or operated by one or more users (not shown), such as a Sony PlayStation® 5, and/or users/account holders (or potential users/account holders). According to some embodiments, the resource devices 102a-n and/or the user devices 106a-n may communicate with the central controller 110 either directly or via the network 104 as described herein.
According to some embodiments, the peripheral devices 107a-n, 107p-z may comprise any type or configuration of computing, mobile electronic, network, user, and/or communication devices that are or become known or practicable. The peripheral devices 107a-n, 107p-z may, for example, comprise one or more of computer mice, computer keyboards, headsets, cameras, touchpads, joysticks, game controllers, watches (e.g., smart watches), microphones, etc. In various embodiments, peripheral devices may comprise one or more of Personal Computer (PC) devices, computer workstations, video game consoles, tablet computers, laptops, and the like. The network 104 may, according to some embodiments, comprise a Local Area Network (LAN; wireless and/or wired), cellular telephone, Bluetooth®, Near Field Communication (NFC), and/or Radio Frequency (RF) network with communication links between the central controller 110, the resource devices 102a-n, the user devices 106a-n, and/or the third-party device 108. In some embodiments, the network 104 may comprise direct communication links between any or all of the components 102a-n, 104, 106a-n, 107a-n, 107p-z, 108, 110 of the system 100. The resource devices 102a-n may, for example, be directly interfaced or connected to one or more of the central controller 110, the user devices 106a-n, the peripheral devices 107a-n, 107p-z and/or the third-party device 108 via one or more wires, cables, wireless links, and/or other network components, such network components (e.g., communication links) comprising portions of the network 104. In some embodiments, the network 104 may comprise one or many other links or network components other than those depicted in
While the network 104 is depicted in
According to some embodiments, the third-party device 108 may comprise any type or configuration of a computerized processing device, such as a PC, laptop computer, computer server, database system, and/or other electronic device, devices, or any combination thereof. In some embodiments, the third-party device 108 may be owned and/or operated by a third-party (i.e., an entity different than any entity owning and/or operating either the resource devices 102a-n, the user devices 106a-n, the peripheral devices 107a-n and 107p-z, or the central controller 110; such as a business customer or client of the central controller). The third-party device 108 may, for example, comprise an advertiser that provides digital advertisem*nts for incorporation by the central controller 110 into a multiplayer video game, and which pays the central controller to do this. The third-party device 108 may, as another example, comprise a streaming channel that purchases footage of video games from the central controller.
According to some embodiments, the third-party device 108 may comprise a plurality of devices and/or may be associated with a plurality of third-party entities. In some embodiments, the third-party device 108 may comprise the memory device (or a portion thereof), such as in the case the third-party device 108 comprises a third-party data storage service, device, and/or system, such as the Amazon® Simple Storage Service (Amazon® S3™) available from Amazon®.com, Inc. of Seattle, WA or an open-source third-party database service, such as MongoDB™ available from MongoDB, Inc. of New York, NY. In some embodiments, the central controller 110 may comprise an electronic and/or computerized controller device, such as a computer server and/or server cluster communicatively coupled to interface with the resource devices 102a-n and/or the user devices 106a-n, and/or the peripheral devices 107a-n and 107p-z, and/or local network 109 (directly and/or indirectly). The central controller 110 may, for example, comprise one or more PowerEdge™ M910 blade servers manufactured by Dell®, Inc. of Round Rock, TX, which may include one or more Eight-Core Intel® Xeon® 7500 Series electronic processing devices. According to some embodiments, the central controller 110 may be located remotely from one or more of the resource devices 102a-n and/or the user devices 106a-n and/or the peripheral devices 107a-n and 107p-z. The central controller 110 may also or alternatively comprise a plurality of electronic processing devices located at one or more various sites and/or locations (e.g., a distributed computing and/or processing network).
According to some embodiments, the central controller 110 may store and/or execute specially programmed instructions (not separately shown in
In some embodiments, the resource devices 102a-n, the user devices 106a-n, the third-party device 108, the peripheral devices 107a-n and 107p-z and/or the central controller 110 may be in communication with and/or comprise a memory device (not shown). The memory device may comprise, for example, various databases and/or data storage mediums that may store, for example, user information, meeting information, cryptographic keys and/or data, login and/or identity credentials, and/or instructions that cause various devices (e.g., the central controller 110, the third-party device 108, resource devices 102a-n, the user devices 106a-n, the peripheral devices 107a-n and 107p-z) to operate in accordance with embodiments described herein.
The memory device may store, for example, various AI code and/or mobile device applications and/or interface generation instructions, each of which may, when executed, participate in and/or cause meeting enhancements, improvements to meeting performance, reductions in emissions associated with meeting, enhancements to online gameplay, or any other result or outcome as described herein. In some embodiments, the memory device may comprise any type, configuration, and/or quantity of data storage devices that are or become known or practicable. The memory device may, for example, comprise an array of optical and/or solid-state hard drives configured to store predictive models (e.g., analysis formulas and/or mathematical models and/or models for predicting emissions), credentialing instructions and/or keys, and/or various operating instructions, drivers, etc. In some embodiments, the memory device may comprise a solid-state and/or non-volatile memory card (e.g., a Secure Digital (SD) card such as an SD Standard-Capacity (SDSC), an SD High-Capacity (SDHC), and/or an SD eXtended-Capacity (SDXC)) and any various practicable form-factors, such as original, mini, and micro sizes, such as are available from Western Digital Corporation of San Jose, CA. In various embodiments, the memory device may be a stand-alone component of the central controller 110. In various embodiments, the memory device 140 may comprise multiple components. In some embodiments, a multi-component memory device may be distributed across various devices and/or may comprise remotely dispersed components. Any or all of the resource devices 102a-n, the user devices 106a-n, the peripheral devices 107a-n and 107p-z, the third-party device 108, and/or the central controller 110 may comprise the memory device or a portion thereof, for example.
Resource Devices
Turning now to
According to an embodiment, the instructions of any or all of the software module(s) or programs described with respect to
In various embodiments, processor 205 is in communication with a network port 210 and a data storage device 215. Network port 210 may include any means for resource device 102a to connect to and/or communicate over a network. Network port 210 may include any means for resource device 102a to connect to and/or communicate with another device (e.g., with another electronic device). For example, network port 210 may include a network interface controller, network interface adapter, LAN adapter, or the like. Network port 210 may include a transmitter, receiver, and/or transceiver. Network port 210 may be capable of transmitting signals, such as wireless, cellular, electrical, optical, NFC, RFID, or any other signals. In various embodiments, network port 210 may be capable of receiving signals, such as wireless, cellular, electrical, optical, or any other signals. Storage device 215 may include memory, storage, and the like for storing data and/or computer instructions. Storage device 215 may comprise one or more hard disk drives, solid state drives, random access memory (RAM), read only memory (ROM), and/or any other memory or storage. Storage device 215 may store resource data 220, which may include tables, files, images, videos, audio, or any other data. Storage device 215 may store program 225. Program 225 may include instructions for execution by processor 205 in order to carry out various embodiments described herein. Further, resource data 220 may be utilized (e.g., referenced) by processor 205 in order to carry out various embodiments described herein. It will be appreciated that, in various embodiments, resource device 102a may include more or fewer components than those explicitly depicted.
User Devices
Turning now to
Suitable devices that could act as a user device include: Laptops (e.g., MacBook® Pro, MacBook® Air, HP® Spectre™ x360, Google® Pixelbook™ Go, Dell® XPS™ 13); Desktop computers (e.g., Apple® iMac 5K, Microsoft® Surface™ Studio 2, Dell® Inspiron™ 5680); Tablets (e.g., Apple® iPad® Pro 12.9, Samsung® Galaxy™ Tab S6, iPad® Air, Microsoft® Surface™ Pro); Video game systems (e.g., PlayStation® 5, Xbox® One, Nintendo® Switch™, Super NES® Classic Edition, Wii U®); Smartphones (e.g., Apple® iPhone® 12 Pro or Android® device such as Google® Pixel™ 4 and OnePlus™ 7 Pro); IP enabled desk phone; Watches (e.g., Samsung® Galaxy® Watch, Apple® Watch 5, Fossil® Sport, TicWatch™ E2, Fitbit® Versa™ 2); Room AV Controller (e.g., Crestron® Fusion, Google® Meet hardware); Eyeglasses (e.g., Iristick.Z1™ Premium, Vuzix® Blade, Everysight®Raptor™, Solos®, Amazon® Echo™ Frames); Wearables (e.g., watch, headphones, microphone); Digital assistant devices (e.g., Amazon® Alexa® enabled devices, Google® Assistant, Apple® Siri™); or any other suitable devices. In various embodiments, user device 106a comprises a processor 305. As with processor 205, processor 305 may be any suitable processor, logic chip, controller, or the like.
In various embodiments, processor 305 is in communication with a network port 310, connection port 315, input device 320, output device 325, sensor 330, screen 335, power source 340, and a data storage device 345. As with network port 210, network port 310 may include any means for user device 106a to connect to and/or communicate over a network. Network port 310 may comprise similar components and may have similar capabilities as does network port 210, so the details need not be repeated. Connection port 315 may include any means for connecting or interfacing with another device or medium, such as with a peripheral device (e.g., a headset, mouse, a keyboard), a storage medium or device (e.g., a DVD, a thumb drive, a memory card, a CD), or any other device or medium. Connection port 315 may include a USB port, HDMI port, DVI port, VGA port, Display port, Thunderbolt, Serial port, a CD drive, a DVD drive, a slot for a memory card, or any variation thereof, or any iteration thereof, or any other port. Input device 320 may include any component or device for receiving user input or any other input. Input device 320 may include buttons, keys, trackpads, trackballs, scroll wheels, switches, touch screens, cameras, microphones, motion sensors, biometric sensors, or any other suitable component or device. Input device 320 may include a keyboard, power button, eject button, fingerprint button, or any other device.
Output device 325 may include any component or device for outputting or conveying information, such as to a user. Output device 325 may include a display screen, speaker, light, backlight, projector, LED, touch bar, haptic actuator, or any other output device. Sensor 330 may include any component or device for receiving or detecting environmental, ambient, and/or circ*mstantial conditions, situations, or the like. Sensor 330 may include a microphone, temperature sensor, light sensor, motion sensor, accelerometer, inertial sensor, gyroscope, contact sensor, angle sensor, or any other sensor. Screen 335 may include any component or device for conveying visual information, such as to a user. Screen 335 may include a display screen and/or a touch screen. Screen 335 may include a CRT screen, LCD screen, projection screen, plasma screen, LED screen, OLED screen, DLP screen, laser projection screen, virtual retinal display, or any other screen.
Power source 340 may include any component or device for storing, supplying and/or regulating power to user device 106a and/or to any components thereof. Power source 340 may include a battery, ultra-capacitor, power supply unit, or any other suitable device. Power source 340 may include one or more electrical interfaces, such as a plug for connecting to an electrical outlet. Power source 340 may include one or more cords, wires, or the like for transporting electrical power, such as from a wall outlet and/or among components of user device 106a.
Storage device 345 may include memory, storage, and the like for storing data and/or computer instructions. Storage device 345 may comprise one or more hard disk drives, solid state drives, random access memory (RAM), read only memory (ROM), and/or any other memory or storage. Storage device 345 may store data 350, which may include tables, files, images, videos, audio, or any other data. Storage device 345 may store program 355. Program 355 may include instructions for execution by processor 305 in order to carry out various embodiments described herein. Further, data 350 may be utilized (e.g., referenced) by processor 305 in order to carry out various embodiments described herein. It will be appreciated that, in various embodiments, user device 106a may include more or fewer components than those explicitly depicted. It will be appreciated that components described with respect to user device 106a need not necessarily be mutually exclusive. For example, in some embodiments, an input device 320 and a screen 335 may be the same (e.g., a touch screen). For example, in some embodiments, an input device 320 and a sensor 330 may be the same (e.g., a microphone). Similarly, components described herein with respect to any other device need not necessarily be mutually exclusive.
Peripheral Devices
Turning now to
Peripheral device 107a may include various components. Peripheral device 107a may include a processor 405, network port 410, connector 415, input device 420, output device 425, sensor 430, screen 435, power source 440, and storage device 445. Storage device 445 may store data 450 and program 455. A number of components for peripheral device 107a depicted in
In various embodiments, connector 415 may include any component capable of interfacing with a connection port (e.g., with connection port 315). For example, connector 415 may physically complement connection port 315. Thus, for example, peripheral device 107a may be physically connected to a user device via the connector 415 fitting into the connection port 315 of the user device. The interfacing may occur via plugging, latching, magnetic coupling, or via any other mechanism. In various embodiments, a peripheral device may have a connection port while a user device has a connector. Various embodiments contemplate that a user device and a peripheral device may interface with one another via any suitable mechanism. In various embodiments, a user device and a peripheral device may interface via a wireless connection (e.g., via Bluetooth®, Near Field Communication, or via any other means).
A peripheral may include one or more sensors 430. These may include mechanical sensors, optical sensors, photo sensors, magnetic sensors, biometric sensors, or any other sensors. A sensor may generate one or more electrical signals to represent a state of a sensor, a change in state of the sensor, or any other aspect of the sensor. For example, a contact sensor may generate a “1” (e.g., a binary one, e.g., a “high” voltage) when there is contact between two surfaces, and a “0” (e.g., a binary “0”, e.g., a “low” voltage) when there is not contact between the two surfaces. A sensor may be coupled to a mechanical or physical object, and may thereby sense displacement, rotations, or other perturbations of the object. In this way, for example, a sensor may detect when a button has been depressed (e.g., contact has occurred between a depressible surface of a button and a fixed supporting surface of the button), when a wheel has been turned (e.g., a spoke of the wheel has blocked incident light onto an optical sensor), or when any other perturbation has occurred. In various embodiments, sensor 430 may be coupled to input device 420, and may thereby sense user inputs at the input device (e.g., key presses; e.g., mouse movements, etc.).
In various embodiments, sensor 430 may detect more than binary states. For example, sensor 430 may detect any of four different states, any of 256 different states, or any of a continuous range of states. For example, a sensor may detect the capacitance created by two parallel surfaces. The capacitance may change in a continuous fashion as the surfaces grow nearer or further from one another. The processor 405 may detect the electrical signals generated by sensor 430. The processor may translate such raw sensor signals into higher-level, summary, or aggregate signals. For example, processor 405 may receive a series of “1-0” signals from the sensor that is repeated 45 times. Each individual “1-0” signal may represent the rotation of a mouse wheel by 1 degree. Accordingly, the processor may generate a summary signal indicating that the mouse wheel has turned 45 degrees. As will be appreciated, aggregate or summary signals may be generated in many other ways. In some embodiments, no aggregate signal is generated (e.g., a raw sensor signal is utilized).
In various embodiments, processor 405 receives an electrical signal from sensor 430 that is representative of 1 out of numerous possible states. For example, the electrical signal may represent state number 139 out of 256 possible states. This may represent, for example, the displacement by which a button has been depressed. The processor may then map the electrical signal from sensor 430 into one of only two binary states (e.g., ‘pressed’ or ‘not pressed’). To perform the mapping, the processor 405 may compare the received signal to a threshold state. If the state of the received signal is higher than the threshold state, then the processor may map the signal to a first binary state, otherwise the signal is mapped to a second binary state. In various embodiments, the threshold may be adjustable or centrally configurable. This may allow, for example, the processor 405 to adjust the amount of pressure that is required to register a “press” or “click” of a button.
Processor 405 may create data packets or otherwise encode the summary signals. These may then be transmitted to a user device (e.g., device 106b) via connector 415 (e.g., if transmitted by wired connection), via network port 410 (e.g., if transmitted by network; e.g., if transmitted by wireless network), or via any other means. User device 106b may include a computer data interface controller (e.g., as network port 410; e.g., as connector 415; e.g., as part of network port 410; e.g., as part of connector 415; e.g., in addition to network port 410 and/or connector 415), which may receive incoming data from peripheral device 107a. The incoming data may be decoded and then passed to a peripheral driver program on the user device 106b. In various embodiments, different models or types of peripheral devices may require different drivers. Thus, for example, user device 106b may include a separate driver for each peripheral device with which it is in communication. A driver program for a given peripheral device may be configured to translate unique or proprietary signals from the peripheral device into standard commands or instructions understood by the operating system on the user device 106b. Thus, for example, a driver may translate signals received from a mouse into a number of pixels of displacement of the mouse pointer. The peripheral device driver may also store a current state of the peripheral device, such as a position of the device (e.g., mouse) or state of depression of one or more buttons. A driver may pass peripheral device states or instructions to the operating system as generated, as needed, as requested, or under any other circ*mstances. These may then be used to direct progress in a program, application, process, etc.
Sensors
Various embodiments may employ sensors (e.g., sensor 330; e.g., sensor 430). Various embodiments may include algorithms for interpreting sensor data. Sensors may include microphones, motion sensors, tactile/touch/force sensors, voice sensors, light sensors, air quality sensors, weather sensors, indoor positioning sensors, environmental sensors, thermal cameras, infrared sensors, ultrasonic sensors, fingerprint sensors, brainwave sensors (e.g., EEG sensors), heart rate sensors (e.g., EKG sensors), muscle sensors (e.g., EMG electrodes for skeletal muscles), barcode and magstripe readers, speaker/ping tone sensors, galvanic skin response sensors, sweat and sweat metabolite sensors and blood oxygen sensors (e.g., pulse oximeters), electrodermal activity sensors (e.g., EDA sensors), or any other sensors. Algorithms may include face detection algorithms, voice detection algorithms, or any other algorithms.
Motion sensors may include gyroscopes, accelerometers, Wi-Fi® object sensing (e.g., using Wi-Fi® signals that bounce off of objects in a room to determine the size of an object and direction of movement), magnetometer combos (inertia measurement units), or any other motion sensors. Motion sensors may be 6 or 9 axis sensors, or sensors along any other number of axes. Motion sensors may be used for activity classification. For example, different types of activities such as running, walking, cycling, typing, etc., may have different associated patterns of motion. Motion sensors may therefore be used in conjunction with algorithms for classifying the recorded motions into particular activities. Motion sensors may be used to track activity in a restricted zone of a building, identify whether an individual is heading toward or away from a meeting, as a proxy for level of engagement in a meeting, steps taken, calories burned, hours slept, quality of sleep, or any other aspect of user activity. Motion sensors may be used to quantify the amount of activity performed, e.g., the number of steps taken by a user. Motion sensors can also be used to track the movement of objects, such as the velocity or distance traveled of a user's mouse. Motion sensors may be used to identify whether an individual is approaching an entry to a house, and if so, trigger a doorbell within the house, and send an alert to a user device or peripheral devices of a user associated with the house.
Motion sensors may use passive infrared (PIR) technology which can detect body and changes in body temperatures. Motion sensors using microwave technology send out microwave pulses and measure how those pulses bounce off moving objects. Ultrasonic motion sensors are another option. Motion sensors can also employ dual use technology by combining multiple detection methods, such as using both passive infrared and microwave technologies. Vibration motion sensors can pick up vibrations caused by people walking through a room. Area reflective motion sensors use infrared waves from an LED and can calculate the distance to an object based on the reflection of the waves.
Motion sensors may be used in conjunction with reminders, such as reminders to change activity patterns. For example, if motion sensors have been used to detect that a user has been sitting for a predetermined period of time, or that the user has otherwise been sedentary, a reminder may be generated for the user to encourage the user to stand up or otherwise engage in some physical activity.
Motion sensors may be used to detect wrist gestures, such as shakes, taps or double taps, or twists. Motion sensors may detect device orientation (e.g., landscape/portrait mode, vertical orientation). A motion sensor may include a freefall sensor. A freefall sensor may be used to monitor handling of packages/devices (e.g., that packages were not dropped or otherwise handled too roughly) or to protect hard drives (e.g., to refrain from accessing the hard drive of a device if the device is undergoing too much motion). In various embodiments, accelerometers may be used as microphones. For example, accelerometers may detect vibrations in air, in a membrane, or in some other medium caused by sound waves.
Tactile/touch/force sensors may include sensors that are sensitive to force, such as physical pressure, squeezing, or weight. Flex sensors may sense bending. 3-D accelerometers, such as the Nunchuck®/Wiichuck®, may sense motion in space (e.g., in three dimensions). Light sensors may sense ambient light. Light sensors, such as RGB sensors, may sense particular colors or combinations of colors, such as primary colors (e.g., red green and blue). Light sensors may include full spectrum luminosity sensors, ultraviolet (UV) sensors, infrared (IR) sensors, or any other sensors. Light sensors may include proximity sensors. Indoor positioning sensors may include sensors based on dead reckoning, pedestrian dead reckoning (such as the combination of accelerometer and gyroscope, including systems unreliable on infrastructure), geomagnetic or RF signal strength mapping, Bluetooth® beacons, or based on any other technology. Environmental sensors may include barometers, altimeters, humidity sensors, smoke detectors, radiation detectors, noise level sensors, gas sensors, temperature sensors (e.g., thermometers), liquid flow sensors, and any other sensors. Infrared sensors may be used to detect proximity, body temperature, gestures, or for any other application. Ultrasonic sensors may be used for range-finding, presence/proximity sensing, object detection and avoidance, position tracking, gesture tracking, or for any other purpose.
Outputs
In various embodiments, outputs may be generated by various components, devices, technologies, etc. For example, outputs may be generated by output device 325 and/or by output device 425. Outputs may take various forms, such as lights, colored lights, images, graphics, sounds, melodies, music, tones, vibrations, jingles, spoken words, synthesized speech, sounds from games, sounds from video games, etc. Light outputs may be generated by light emitting diodes (LED's), liquid crystals, liquid crystal displays (LCD's), incandescent lights, display screens, electronic ink (E-ink), e-skin, or by any other source. In various embodiments, outputs may include vibration, movement, or other motion. Outputs may include force feedback or haptic feedback. Outputs may include temperature, such as through heating elements, cooling elements, heat concentrating elements, fans, or through any other components or technologies. In various embodiments, an output component may include a motor. A motor may cause a mouse to move on its own (e.g., without input of its owner). In various embodiments, a first mouse is configured to mirror the motions of a second mouse. That is, for example, when the other second mouse is moved by a user, the motor in the first mouse moves the first mouse in a series of motions that copy the motions of the second mouse. In this way, for example, a first user can see the motions of another user reflected in his own mouse. In various embodiments, outputs may take the form of holograms. In various embodiments, outputs may take the form of scents or odors or vapors. These may be generated with dispensers, for example. In various embodiments, outputs may consist of alterations to an in-home (or other indoor) environment. Outputs may be brought about by home control systems. Alterations to the environment may include changing temperature, humidity, light levels, state of window shades (e.g., open are closed), state of door locks, security cameras settings, light projections onto walls, or any other alteration.
Third-Party Devices
Turning now to
Central Controllers
Turning now to
In various embodiments, the central controller may include one or more servers located at the headquarters of a company, a set of distributed servers at multiple locations throughout the company, or processing/storage capability located in a cloud environment—either on premise or with an outside vendor such as Amazon® Web Services, Google® Cloud Platform, or Microsoft® Azure™ In various embodiments, the central controller may be a central point of processing, taking input from one or more of the devices herein, such as a user device or peripheral device. The central controller has processing and storage capability along with the appropriate management software as described herein. In various embodiments, the central controller may include an operating system, such as Linux, Windows® Server, Mac® OS X Server, or any other suitable operating system.
Communications with the central controller could include user devices, game controllers, peripheral devices, outside websites, conference room control systems, video communication networks, remote learning communication networks, game consoles, streaming platforms, corporate data systems, etc. In various embodiments, the central controller may include hardware and software that interfaces with user devices and/or peripheral devices in order to facilitate communications. The central controller may collect analytics from devices (e.g., user device, e.g., peripheral devices). Analytics may be used for various purposes, such as for the purpose of enhancing the experience of a user.
In various embodiments, the central controller may perform various other functions, such as authenticating users, maintaining user accounts, maintaining user funds, maintaining user rewards, maintaining user data, maintaining user work products, hosting productivity software, hosting game software, hosting communication software, facilitating the presentation of promotions to the user, allowing one user to communicate with another, allowing a peripheral device to communicate with another, or any other function.
In various embodiments, the central controller may include software for providing notifications and/or status updates. The central controller may notify a user when one or more other users is present (e.g., at their respective office locations, e.g., at their respective home computers), when another user wishes to communicate with the user, when a collaborative project has been updated, when the user has been mentioned in a comment, when the user has been assigned work, when the user's productivity has fallen, when the user has been invited to play in a game, or in any other circ*mstance. Notifications or status updates may be sent to peripheral devices, user devices, smartphones, or to any other devices.
In various embodiments, the central controller may include voting software. The voting software may facilitate voting, decision-making, or other joint or group action. Example votes may determine a plan of action at a company, or a strategy in a team video game. Voting software may permit users or other participants to receive notification of votes, receive background information about decisions or actions they are voting on, cast their votes, and see the results of votes. Voting software may be capable of instituting various protocols, such as multiple rounds of runoffs, win by the majority, win by the plurality, win by unanimous decision, anonymous voting, public voting, secure voting, differentially weighted votes, voting for slates of decisions, or any other voting protocol, or any other voting format. Voting results may be stored in data storage device 615, or sent to other devices for storage.
Game Controllers
In various embodiments, a game controller may include software and/or hardware that interfaces with the user device in order to facilitate game play. Example games include Pokemon®, Call of Duty®, Wii®, League of Legends®, Clash of Clans™, Madden® NFL®, Minecraft®, Guitar Hero®, Fortnite®, solitaire, poker, chess, go, backgammon, bridge, Magic: The Gathering®, Scrabble®, etc. In various embodiments, a game controller may be part of the central controller 110. In various embodiments, a game controller may be in communication with the central controller 110, and may exchange information as needed. In various embodiments, a game controller may be a standalone device or server (e.g., a server accessed via the internet). In various embodiments, a game controller could be housed within a user computer. In various embodiments, a game controller may be part of, or may operate on any suitable device. In various embodiments, the game controller enables gameplay and can communicate with a user device and one or more computer peripherals. In various embodiments, a game controller may perform such functions as maintaining a game state, updating a game state based on user inputs and game rules, creating a rendering of a game state, facilitating chat or other communication between players of a game, maintaining player scores, determining a winner of a game, running tournaments, determining a winner of a tournament, awarding prizes, showing in-game advertisem*nts, are performing any other function related to a game, or performing any other function.
Data Structures
It will be appreciated that
It will be appreciated that, in various embodiments, one or more tables described herein may show representative rows of data elements. Rows are not necessarily shown in any particular order. The rows are not necessarily shown starting from the beginning nor approaching the end in any conceivable ordering of rows. Consecutive rows are not necessarily shown. In some embodiments, fewer or more data fields than are shown may be associated with the data tables (e.g., of
In various embodiments, data or rows that are depicted herein as occurring in separate or distinct data tables may actually be stored in the same data tables. In various embodiments, two or more data tables may share the same name (e.g., such data tables may be stored in different locations, on different devices, or stored in any other fashion). Such data tables may or may not store the same types of data, may or may not have the same fields, and may or may not be used in the same way, in various embodiments. For example, central controller 110 may have a “user” data table, and third-party device 108 may be an online gaming platform that also has a “user” data table. However, the two tables may not refer to the same set of users (e.g., one table may store owners of peripheral devices, while the other table may store rated online game players), and the two tables may store different information about their respective users. In various embodiments, data tables described herein may be stored using a data storage device (e.g., storage device 615) of central controller 110. For example, “data” 620 may include data tables associated with the central controller 110, which may reside on storage device 615. Similarly, “data” 520 may include data tables associated with the third-party device 108, which may reside on storage device 515. In various embodiments, data tables associated with any given device may be stored on such device and/or in association with such device.
Referring to
As depicted in
Nicknames field 712 may store a user nickname, alias, screen name, character name, or the like. The nickname may be a name by which a user will be known to others in one or more contexts, such as in a game or in a meeting. In various embodiments, a user may have more than one nickname (e.g., one nickname in a first context and another nickname in a second context). Financial account information field 716 may store information about a financial account associated with the user, such as a credit or debit card, bank account, stored value account, PayPal® account, Venmo® account, rewards account, coupons/discounts, crypto currency account, bitcoin account, or any other account. With this information stored, a user may be given access to peruse his account balances or transaction history, for example. A user may be rewarded through additions to his account, and charged through deductions to his account. In various embodiments, a user may utilize his account to pay another user or receive payment from another user. Various embodiments contemplate other uses for financial account information. User table 700 depicts several fields related to demographic information (e.g., marital status field 720, gender field 722, and primary language field 724). In various embodiments, other items of demographic information may be stored, such as number of children, income, country of origin, etc. In various embodiments, fewer items of demographic information may be stored. Images field 726 may store one or more images associated with a user. An image may include an actual photograph of a user (e.g., through a webcam). The image may be used to help other users recognize or identify with the user. In various embodiments, image field 726 may store an item favored by the user, such as the user's pet or favorite vacation spot. In various embodiments, image field 726 may store an image of a character or avatar (e.g., an image by which the user wishes to be identified in a game or other online environment).
Referring to
In various embodiments, network table 800 may store characteristics of any other network. Network ID field 802 may include an identifier (e.g., unique identifier) for a user's network. Network name field 804 may store a name, such as a human readable name, nickname, colloquial name, or the like for a user's network. Network IP address field 806 may store an IP address for the network, such as an externally facing IP address. User ID field 808, may store an indication of a user who owns this network, if applicable. In various embodiments, the network may be owned by some other entity such as a company, office, government agency etc. Specified connection speed field 810 may store a specified, advertised, and/or promised connection speed for a network. The connection speed that is realized in practice may differ from the specified connection speed. Actual upload-speed field 812 may store an indication of an upload speed that is or has been realized in practice. For example, the upload speed may store an indication of the upload speed that has been realized in the past hour, in the past 24 hours, or during any other historical time frame. The upload speed may measure the rate at which a network is able to transmit data.
Actual download-speed field 814 may store an indication of a download speed that is or has been realized in practice (such as during some historical measurement period). The download speed may measure the rate at which a network is able to receive data. The download speed may be important, for example, in determining what types of videos may be streamed to a user network and/or user device. Encryption type field 816 may store an indication of the security that is present on the network. In some embodiments, field 816 stores the type of encryption used by the network. For example, this type of encryption may be used on data that is communicated within the network. In some embodiments, field 816 may store an indication of the security measures that a user must undergo in order to access data that has been transmitted through the network. For example, field 816 may indicate that a user must provide a password or biometric identifiers in order to access data that has been transmitted over the network. Uptime percentage field 818 may store an indication of the amount or the percentage of time when a network is available and/or functioning as intended. For example, if a network is unable to receive data for a one-hour period (perhaps due to a thunderstorm), then the one-hour period may count against the network uptime percentage. In various embodiments, an uptime percentage may be used to determine activities in which a user may engage. For example, a user may be allowed to participate in a multi-person video conference or video game requiring extensive team communication, only if the user's network uptime exceeds a certain minimum threshold.
Referring to
Model field 906 may indicate the model of the user device. Processor field 908 may indicate the processor, CPU, Neural Chip, controller, logic, or the like within the device. In various embodiments, more than one processor may be indicated. Processor speed field 910 may indicate the speed of the processor. Number of cores field 912 may indicate the number of physical or virtual cores in one or more processors of the user device. In various embodiments, the number of cores may include the number of processors, the number of cores per processor, the number of cores amongst multiple processors, or any other suitable characterization. Graphics card field 914 may indicate the graphics card, graphics processor, or other graphics capability of the user device. RAM field 916 may indicate the amount of random access memory possessed by the user device. Storage field 918 may indicate the amount of storage possessed by that user device. Year of manufacture field 920 may indicate the year when the user device was manufactured. Purchase year field 922 may indicate the year in which the user device was purchased by the user.
Operating System field 924 may indicate the operating system that user device is running. MAC Address field 926 may indicate the media access control address (MAC address) of the user device. Physical location field 928 may indicate the physical location of the user device. This may be the same as the owner's residence address, or it may differ (e.g., if the owner has carried the user device elsewhere or is using it at the office, etc.). Timezone field 930 may indicate the time zone in which the user device is located, and or the time zone to which the user device is set. In one example, the central controller may schedule the user device to participate in a video conference call with a particular shared start time for all participants. In another example, the central controller may schedule the user device to participate in a multiplayer game, and wish to alert the user device as to the game's start time using the user device's time zone. Owner ID field 932 may indicate the owner of the user device. The owner may be specified for example in terms of a user ID, which may be cross-referenced to the user table 700 if desired. Network ID(s) field 934 may indicate a network, such as a local network, on which the user device resides. The network may be indicated in terms of a network ID, which may be cross-referenced to the network table 800 if desired.
IP address field 936 may indicate the IP address (or any other suitable address) of the user device. In some embodiments, such as if the user device is on a local network, then the user device's IP address may not be listed. In some embodiments, IP address field 936 may store an internal IP address. In some embodiments, IP address field 936 may store a network IP address, such as the public-facing IP address of the network on which the user device resides. As well be appreciated, user device table 900 may store various other features and characteristics of a user device.
Referring to
IP Address field 1010 may store the IP address, or any other suitable address, of the peripheral device. In some embodiments, such as if the peripheral device is on a local network, then the peripheral device's IP address may not be listed. In some embodiments, IP address field 1010 may store an internal IP address. In some embodiments, IP address field 1010 may store a network IP address, such as the public-facing IP address of the network on which the peripheral device resides. In some embodiments, IP address field 1010 may store the IP address of a user device to which the associated peripheral device is connected.
Physical location field 1012 may store an indication of the physical location of the peripheral device. Owner ID field 1014 may store an indication of the owner of the peripheral device. Linked user device ID(s) field 1016 may store an indication of one or more user devices to which the peripheral device is linked. For example, if a peripheral device is a mouse that is connected to a desktop PC, then field 1016 may store an identifier for the desktop PC. Communication modalities available field 1018 may indicate one or more modalities through which the peripheral device is able to communicate. For example, if a peripheral device possesses a display screen, then video may be listed as a modality. As another example, if a peripheral device has a speaker, then audio may be listed as a modality. In some embodiments, a modality may be listed both for input and for output. For example, a peripheral device with a speaker may have ‘audio’ listed as an output modality, and a peripheral with a microphone may have ‘audio’ listed as an input modality.
In various embodiments, a peripheral device might have the capability to output images, video, characters (e.g., on a simple LED screen), lights (e.g., activating or deactivating one or more LED lights or optical fibers on the peripheral device), laser displays, audio, haptic outputs (e.g., vibrations), altered temperature (e.g., a peripheral device could activate a heating element where the user's hand is located), electrical pulses, smells, scents, or any other sensory output or format. In various embodiments, any one of these or others may be listed as modalities if applicable to the peripheral device. In various embodiments, a peripheral device may have the capability to input images (e.g., with a camera), audio (e.g., with a microphone), touches (e.g., with a touchscreen or touchpad), clicks, key presses, motion (e.g., with a mouse or joystick), temperature, electrical resistance readings, positional readings (e.g., using a positioning system, e.g., using a global positioning system, e.g., by integrating motion data), or any other sensory or any other sensor or any other information. Such input modalities may be listed if applicable to the peripheral device.
In some embodiments, modalities may be specified in greater detail. For example, for a given peripheral device, not only is the video modality specified, but the resolution of the video that can be displayed is specified. For example, a keyboard with a display screen may specify a video modality with up to 400 by 400 pixel resolution. Other details may include number of colors available, maximum and minimum audio frequencies that can be output, frame refresh rate that can be handled, or any other details. Network ID(s) field 1020 may store an indication of a network (e.g., a local network) on which a peripheral device resides. If the peripheral device does not reside on a network, or is not known, then a network may not be indicated. As will be appreciated, peripheral device table 1000 may store one or more other features or characteristics of a peripheral device, in various embodiments.
Referring to
Table 1100 may also store one or more parameters controlling how a peripheral device outputs information. A parameter might include the color of an LED light, the brightness of an LED light, the volume at which audio is output, the temperature to which a heating element is activated, the brightness of a display screen, the color balance of a display screen, or any other parameter of an output. Table 1100 may also store one or more parameters controlling a physical aspect or configuration of a peripheral device. A parameter might include the default height of a key on a keyboard, the angle at which a keyboard is tilted, the direction in which a camera is facing, or any other aspect of a peripheral device. Table 1100 may also store one or more parameters controlling the overall functioning of a peripheral device. In some embodiments, parameters may control a delay with which a peripheral device transmits information, a bandwidth available to the peripheral, a power available to the peripheral, or any other aspect of a peripheral device's function or operation.
In various embodiments, table 1100 may also store constraints on how parameters may be altered. Constraints may describe, for example, who may alter a parameter, under what circ*mstances the parameter may be altered, the length of time for which an alteration may be in effect, or any other constraint. Configuration ID field 1102 may store an identifier (e.g., a unique identifier), of a given configuration for a peripheral device. Peripheral device ID field 1104 may store an indication of the peripheral device (e.g., a peripheral device ID) to which the configuration applies. Variable field 1106 may include an indication of which particular parameter, variable, or aspect of a peripheral device is being configured. Example variables include mouse speed, mouse color, key height, etc. Default setting field 1108 may include a default setting for the variable. For example, by default a mouse speed may be set to “fast”. In some embodiments, a default setting may take effect following a temporary length of time in which a parameter has been altered.
Outsider third-party control field 1110 may indicate whether or not the parameter can be modified by an outsider (e.g., by another user; e.g., by an opponent). For example, in some embodiments, a user playing a multiplayer video game may have their peripheral device's performance degraded by an opposing player as part of the ordinary course of the game (e.g., if the opposing player has landed a strike on the player). In some embodiments, table 1100 may specify the identities of one or more outside third-parties that are permitted to alter a parameter of a peripheral device. In some embodiments, an outsider is permitted to alter a parameter of a peripheral device only to within a certain range or subset of values. For example, an outsider is permitted to degrade the sensitivity of a user's mouse, however the sensitivity can only be degraded to as low as 50% of maximum sensitivity.
Current setting field 1112 may store the current setting of a parameter for a peripheral device. In other words, if the user were to use the peripheral device at that moment, this would be the setting in effect. Setting expiration time field 1114 may store the time at which a current setting of the parameter will expire. Following expiration, the value of the parameter may revert to its default value, in some embodiments. For example, if the performance of a user's peripheral device has been degraded, the lower performance may remain in effect only for 30 seconds, after which the normal performance of the peripheral device may be restored. As will be appreciated, an expiration time can be expressed in various formats, such as an absolute time, as an amount of time from the present, or in any other suitable format. Expiration time can also be expressed in terms of a number of actions completed by the user. For example, the current setting may expire once a user has clicked the mouse button 300 times.
Referring to
Peripheral devices may communicate with one another under various circ*mstances. In some embodiments, two users may pass messages to one another via their peripheral devices. A message sent by one user may be displayed on the peripheral device of the other user. In some embodiments, user inputs to one peripheral device may be transferred to another peripheral device in communication with the first. In this way, for example, a first user may control the peripheral device of a second user by manipulating his own peripheral device (i.e., the peripheral device of the first user). For example, the first user may guide a second user's game character through a difficult phase of a video game. As will be appreciated, there are various other situations in which one peripheral device may communicate with another peripheral device.
In various embodiments, peripheral devices may communicate directly with one another, such as with a direct wireless signal sent from one to the other. In various embodiments, one peripheral device communicates with another peripheral device via one or more intermediary devices. Such intermediary devices may include, for example, a user device, a router (e.g., on a local network), the central controller, or any other intermediary device. In other embodiments, one peripheral device may communicate with two or more other peripheral devices at the same time.
As shown, table 1200 indicates a connection between a first peripheral device and a second peripheral device in each row. However, as will be appreciated, a table may store information about connections in various other ways. For example, in some embodiments, a table may store information about a three-way connection, a four-way connection, etc. Connection ID field 1202 may store an identifier (e.g., a unique identifier) for each connection between a first peripheral device and a second peripheral device. Peripheral device 1 ID field 1204 may store an indication of the first peripheral device that is part of the pair of connected devices. Peripheral device 2 ID field 1206 may store an indication of the second peripheral device that is part of the pair of connected devices. Time field 1208 may store the time when the connection was made and/or terminated. Action field 1210 may store the action that was taken. This may include the relationship that was created between the two peripheral devices. Example actions may include initiating a connection, terminating a connection, initiating a limited connection, or any other suitable action.
Maximum daily messages field 1212 may store one or more limits or constraints on the communication that may occur between two peripheral devices. For example, there may be a limit of one thousand messages that may be exchanged between peripheral devices in a given day. As another example, there may be constraints on the number of words that can be passed back and forth between peripheral devices in a given day. Placing constraints on communications may serve various purposes. For example, the owner of a peripheral device may wish to avoid the possibility of being spammed by too many communications from another peripheral device. As another example, the central controller may wish to limit the communications traffic that it must handle.
Referring to
Settings field 1308 may include one or more settings or guidelines or rules by which peripheral devices within the group may interact with one another and/or with an external device or entity. In various embodiments, a setting may govern communication between the devices. For example, one setting may permit device-to-device messaging amongst any peripheral devices within the group. One setting may permit any peripheral device in a group to control any other peripheral device in the group. One setting may permit all peripheral devices in a group to interact with a particular online video game. As will be appreciated, these are but some examples of settings and many other settings are possible and contemplated according to various embodiments. Formation time field 1310 may store an indication of when the group was formed. Group leader device field 1312 may store an indication of which peripheral device is the leader of the group. In various embodiments, the peripheral device that is the leader of a group may have certain privileges and/or certain responsibilities. For example, in a meeting group, the group leader device may be the only device that is permitted to start the meeting or to modify a particular document being discussed in the meeting.
Member peripheral devices field 1314 may store an indication of the peripheral devices that are in the group. Referring to
User 2 ID field 1406 may identify a second user that is part of a connection.
Time field 1408 may indicate a time when a connection was made, terminated, or otherwise modified. Action field 1410 may indicate an action or status change that has taken effect with respect to this connection. For example, the action field may be ‘initiate connection’, ‘terminate connection’, ‘initiate limited connection’, or any other modification to a connection. Relationship field 1412 may indicate a type of relationship or a nature of the connection. For example, two users may be related as friends, teammates, family members, co-workers, neighbors, or may have any other type of relationship or connection. Maximum daily messages field 1414 may indicate one or more constraints on the amount of communication between two users. For example, a user may be restricted to sending no more than one hundred messages to a connected user in a given day. The restrictions may be designed to avoid excessive or unwanted communications or to avoid overloading the central controller, for example. Various embodiments may include many other types of restrictions or constraints on the connection or relationship between two users.
Referring to
Referring to
Referring to
Reward field 1712 may indicate a reward, acknowledgement, or other recognition that has or will be provided to the user for the achievement. Example rewards may include: the user's office mouse glows purple for the whole day of Jul. 22, 2020; a congratulatory message is sent to all users in the same game group; the user receives three free music downloads; the user receives a financial payment (such as money, digital currency, game currency, game items, etc.); the user receives a discount coupon or promotional pricing, the user's name is promoted within a game environment; the user's video conference photo is adorned with a digital crown, or any other reward. Provided field 1714 may indicate whether or not the reward has been provided yet. In some embodiments, table 1700 may also store an indication of a time when a reward has been or will be provided.
Referring to
Currency type field 1808 may store an indication of the type of currency in the stored-value account. The currency may include such traditional currencies as dollars or British pounds. The currency may also include stock certificates, bonds, cryptocurrency, game currency, game tokens, coupons, discounts, employee benefits (e.g., one or more extra vacation days), game skins, game objects (e.g., a +5 sword, a treasure map), cheat codes, merchant rewards currency, or any other type of currency or stored value. Balance field 1810 may store a balance of funds that the user has in her stored-value account. In some embodiments, a negative balance may indicate that a user has overdrawn an account and/or owes funds to the account. Hold amount field 1812 may indicate an amount of a hold that has been placed on funds in the user account. The hold may restrict the user from withdrawing funds beyond a certain amount, and/or may require the user to leave at least a certain amount in the account. The hold may ensure, for example, that that the user is able to meet future obligations, such as financial obligations.
Referring to
Asset ID field 1902 may store an identifier (e.g., a unique identifier) for a digital asset. Type field 1904 may store an indication of the type of asset, such as ‘movie’, ‘music’, ‘video game’, ‘podcast’, etc. Title field 1906 may store a title associated with the asset. For example, this might be the title of a movie, the title of a song, the title of a class, etc. Director field 1908 may store an indication of a director of a movie or other asset. In various embodiments, table 1900 may store an indication of any contributor to the making of a digital asset. For example, table 1900 may store an indication of a songwriter, producer, choreographer, creator, developer, author, streamer, editor, lecturer, composer, cinematographer, dancer, actor, singer, costume designer, or of any other contributor. Artist field 1910 may store an indication of the artist associated with an asset. The artist may be, for example, the singer of a song. The artist could also be the name of a production company that created the asset. Duration field 1912 may store the duration of a digital asset. For example, the duration may refer to the length of a movie, the length of a song, the number of words in a book, the number of episodes in a podcast, or to any other suitable measure of duration. Size field 1914 may store an indication of the size of the digital asset. The size may be measured in megabytes, gigabytes, or in any other suitable format. Synopsis field 1916 may store a synopsis, summary, overview, teaser, or any other descriptor of the digital asset. Reviews field 1918 may store an indication of one or more reviews that are associated with the digital asset. The reviews may come from professional critics, previous users, or from any other source. Reviews may take various forms, including a number of stars, number of thumbs up, an adjective, a text critique, an emoji, or any other form.
Referring to
Referring to
In various embodiments, table 2100 does not store a comprehensive state. Rather, for example, table 2100 may indicate the state of one or more apps, programs, or processes on a user device, such as at a given point in time. In various embodiments, table 2100 may store a substantially complete indication of a state of a user device, such as at a given point in time. In various embodiments, individual rows or records in table 2100 may store a partial state of a user device (e.g., each row may store information about a single app on the user device, such as the prominence of the app). In various embodiments, a more complete or a substantially complete indication of a state of a user device may be ascertained by combining information from multiple rows of table 2100. User device state log ID field 2102 may store an identifier (e.g., a unique identifier) of a state or partial state of a user device. User device ID field 2104 may store an indication of a user device for which the state or partial state is recorded. Time field 2106 may store an indication of a time at which the user device was in a particular state or partial state. Program/app field 2108 may store an indication of a program, app, or other process, such as a program that was running at the time indicated in field 2106. Program/app field 2108 could also store an indication of the operating system version of the user device. Sub-app field 2110 may store an indication of a subordinate program, app, or process, such as a subordinate program that was running at the time indicated in field 2106. The subordinate program, app, or process may be subordinate to the program, app, or process which is stored in field 2108. For example, field 2108 may refer to a browser (e.g., to the Chrome browser), while field 2110 may refer to a particular web page that is being visited by the browser (e.g., to the Google®.com page). Prominence field 2112 may indicate the prominence of the program or app of field 2108 and/or the prominence of the subordinate program or app of field 2110. The prominence may refer to the visibility, or other state of usage for the program, app, etc. Example prominence values may include ‘forefront’, ‘background’, ‘minimized’, ‘sleeping’, ‘first tab’, ‘50% of processor cycles’, ‘last used’, ‘full screen’, or any other indication of a state of usage, etc.
Referring to
Component field 2210 may store the particular component or part of a peripheral device that was involved in an activity. The component field 2210 may store an indication of a button on a mouse, a key on a keyboard, a microphone on a headset, a scroll wheel on a mouse, or any other relevant component of a peripheral device. In some embodiments, the component may be the entire peripheral device, such as when an entire mouse is moved. Action field 2212 may store the action that was performed. Actions may include pressing, tapping, moving, shaking, squeezing, throwing, lifting, changing position (e.g., moving 120 mm in an ‘x’ direction and moving −80 mm in a‘y’ direction) or any other action. Recipient program field 2214 may store the application, program, or other computer process towards which an action was directed. For example, if a user was using the program Microsoft® Paint, then a given action may have been directed towards doing something in Microsoft® Paint, such as drawing a line. In some embodiments, an action may be directed towards an operating system, a browser, or to any other process. In various embodiments, peripheral device activities may be recorded at varying levels of granularity. In some embodiments, every keystroke on a keyboard may be recorded as a separate activity. In some embodiments, the typing of an entire sentence at a keyboard may be recorded as a single activity. In some embodiments, a series of related activities is recorded as a single activity. For example, when a headset shakes back and forth, this may be recorded as a single shake of the headset. In some embodiments, each individual motion of the headset within the shake is recorded as a separate activity. As will be appreciated, various embodiments contemplate that peripheral device activities may be tracked or recorded at any suitable level of granularity.
Referring to
Sensor reading ID field 2302 may store an identifier (e.g., a unique identifier) of a particular sensor reading. Peripheral ID field 2304 may store an indication of the peripheral device at which the sensor reading has been captured. Sensor field 2306 may store an indication of which sensor has captured the reading. For example, sensor field 2306 may explicitly identify a single sensor or type of sensor from among multiple sensors that are present on a peripheral device. The sensor may be identified, for example, as a heart rate sensor. In some embodiments, a sensor may have a given identifier, serial number, component number, or some other means of identification, which may be stored in field 2306. Start time field 2308 may store the time at which a sensor began to take a reading. End time field 2310 may store the time at which a sensor finished taking a reading. As will be appreciated, different sensors may require differing amounts of time in order to capture a reading. For instance, capturing a reading of a heart rate may require the reading to be taken over several seconds in order to allow for multiple heartbeats. Reading field 2312 may store the actual reading that was captured. For example, the field may store a reading of 110 beats per minute for a heart rate. In other embodiments, the reading may be a recording of an EKG signal from the start time to an end time.
Referring to
Referring to
Referring to
In various embodiments, a peripheral device may be in any of two or more different modes or states. For example, a peripheral device might be in “in use” mode, or it might be in “idle” mode. For example, a peripheral device might be in “game” mode, or it might be in “work” mode. When a peripheral device is in a first mode, it may be operable to initiate one or more actions. However, when a peripheral device is in a second mode, it may not be operable to initiate one or more actions. For instance, when a peripheral device is in “game” mode, the peripheral device may be operable to send a message to a teammate with just a few predetermined keystrokes. However, when the same peripheral device is in “work” mode, the same message might, at best, be meaningless, and at worst interfere with work. Mode of peripheral field 2606 may be a mode or state of a peripheral device that is relevant to a particular action. For example, field 2606 may store a mode in which a peripheral device is operable to take an associated action. In some embodiments, field 2606 may store a mode in which a peripheral device is not operable to take an associated action. In various embodiments, a given input sequence may be valid in more than one mode of a peripheral device, however the input sequence may have different meanings in the different modes. Example modes may include action mode, messaging mode, in-use mode, idle mode, etc.
Input Sequence field 2608 may store the user inputs that will trigger an associated action. User inputs may comprise a set of clicks, button presses, motions, or any other set of inputs. Action field 2610 may store an action that the user wishes to take when he provides the user inputs. The action may include a generic action from table 2500, in which case an identifier for such an action from table 2500 may be stored in field 2610. The action may include any other action, message, instruction or the like. In some embodiments, certain actions may be valid only when both an originating peripheral device and a receiving peripheral device are both in the proper modes. For example, in order for a text message to be sent from one peripheral device to another peripheral device, the initiating peripheral device must be in “text” mode, and the receiving peripheral device must be in “idle” mode. In such embodiments, for example, table 2600 may store modes for two peripheral devices (e.g., for both an initiating and for a receiving peripheral device). In some embodiments, the relevant mode is the mode of the receiving peripheral device. In such embodiments, for example, table 2600 made store modes for the receiving peripheral device.
Referring to
Screen name field 2710 may store a screen name, nickname, character name, alias, username, or any other name by which new user may be referenced in a game environment, or in any other environment. Preferred character field 2712 may store an indication of a user's preferred character to use in a game. For example, a game may allow a user to select a particular character to control within the game. Different characters may have different capabilities, different weaknesses, different looks, or other differences. In some embodiments, table 2700 may store a user's preferred role or function within a multiplayer game. For example, users on a team may assume different roles. For example, one user might be a navigator while another user is a gunner. Preferred avatar field 2714 may store an indication of a user's preferred avatar for use in a game, or in any other situation. A user's avatar may represent the way that the user or the user's character appears on screen. An avatar might appear as a human being dressed in a particular way, as a mythical being, as an animal, as a machine, or in any other form. Preferred background music field 2716 may store an indication of a user's preferred background music for use in a game, or in any other environment. Background music may include a melody, a song, a rhythm, a jingle, or any other music. In some embodiments, there may be multiple available music themes, which may be labeled numerically, such as theme 1, theme 2, etc. Field 2716 may then store a theme number as the user's preferred theme. Rating/skill level field 2718 may store an indication of a user's rating, skill level, experience, or any other metric of aptitude within the game. In one example, a user's FIDE chess rating could be stored for use on a chess playing website. Last login field 2720 may store an indication of the time when a user last logged into a game, game environment, game server, or the like. In some embodiments, table 2700 may store a user's login name, which may differ from their screen name. The login name may be used to identify the user when the user first logs in. The screen name may be used within a particular game to identify the user or the user's character within that game. As will be appreciated, login names or screen names may be used for various other purposes.
Referring to
Referring to
Game activity ID field 2902 may include an identifier (e.g., a unique identifier) for a particular activity in a game. Game ID field 2904 may include an indication of a particular game title in which the activity occurred. In some embodiments, field 2904 may include an indication of a particular instance of a game in which an activity occurred. Participant ID field 2906 may include an indication of a participant or player in a game that performed the activity. Start time field 2908 may include an indication of the time when the activity was started or initiated. This time may represent, e.g., a time when a mouse movement was initiated, a time when a character started down a particular road, a time when an attack was ordered, a time when a particular mouse button was pressed, a time when a particular head motion was initiated, etc. End time field 2910 may include an indication of the time when the activity was completed. For example, a mouse movement was completed, an attack was repelled, a bullet hit its mark, etc. Note that, for example, end time 2910 may be mere fractions of a second after start time 2908. This may occur for example when very quick or granular activities are being recorded. However, in some embodiments, an activity may take a longer amount of time.
Game State field 2912 may store an indication of a game state or situation at the time that the activity took place. A game state might include a level within a game, a screen within a game, a location within a virtual world of a game, a health status of a character, an inventory of the possessions of a character, a state of a character (e.g., invisible, e.g., temporarily incapacitated) a location of one or more villains or opponents, a set of playing cards held in a character's hand (e.g., in a poker game), an amount of money or other currency possessed by a player, an amount of money in a pot or kitty (e.g., as in poker), an amount of money remaining with some other game entity (e.g., with the bank in Monopoly), an indication of whose turn it is, a position or location of game pieces or game tokens, an indication of which moves are currently available (e.g., in chess the en passant move is available), an indication of which cards remain in a deck (e.g., in Monopoly® which chance cards are remaining, e.g., in Blackjack, which cards remain in the shoe), or any other aspect of a game state. In some embodiments, a game state may be stored in such detail as to allow the re-creation of the game from that state. Activity field 2914 may include an indication of the activity that was undertaken. Example activities include: shoot; move left; switch to laser weapon; draw 3 cards; e4xd5 (e.g., in chess), etc.
Referring to
Level field 3010 may include an indication of the level where participants are at in the game. This may include a screen, a difficulty level, an environment, a villain, a boss, a game move number, a stage, or any other notion of level. In various embodiments, a game state might include separate information about two or more participants in the game. For example, each participant might have his or her own score, his or her own possessions, his or her own health status, etc. In some embodiments, table 3000 may have separate sets of fields for each participant. For example, each participant might have his or her own score field. Score fields 3012a and 3012b may include scores for a first and a second participant respectively (e.g., for participant ‘a’ and for participant ‘b’). Location fields 3014a and 3014b may include locations for a first and a second participant, respectively. Power field 3016a and 3016b may include power levels for a first and a second participant, respectively. Ammo field 3018a and 3018b may include amounts of ammunition possessed by a first and a second participant, respectively. As will be appreciated, a game may have more than two participants, in various embodiments. In such cases, table 3000 may include additional fields for the additional players. For example, table 3000 may include fields 3012c, 3014c, and so on. The aforementioned represent but some information that may characterize a game state. It will be appreciated that a game state might comprise one or more additional items of information. Further, different games may warrant different descriptions or fields representative of the game state. It is therefore contemplated, according to various and embodiments, that table 3000 may include additional or alternative fields as appropriate to characterizing a game state.
Referring to
Referring to
Referring to
Ad server or agency field 3306 may store an indication of an ad server, an advertising agency, or other intermediary that distributed the ad. Target audience demographics field 3308 may include information about a desired target audience. Such information may include demographic information, e.g., age, race, religion, gender, location, marital status, income, etc. A target audience may also be specified in terms of one or more preferences (e.g., favorite pastimes, e.g., favorite types of vacations, e.g., favorite brand of soap, e.g., political party, etc.). A target audience may also be specified in terms of historical purchases, or other historical behaviors. In some embodiments, a target audience may be specified in terms of video game preferences. Such preferences may be readily available, for example, to a game server. Various environments contemplate that a target audience may be specified in any suitable form, and/or based on any suitable information available. Ad trigger field 3310 may store an indication of what events or circ*mstances should trigger the presentation of an ad to a user. Events may include an initiation of gameplay by the user, a change in a user's performance while playing a game (e.g., a user's rate of play slows down 10%), a certain level being achieved in a game, a certain score being achieved in a game, or any other situation that occurs in a game. Triggers for presenting advertisem*nts may include ambient factors, such as the temperature reaching a certain level, the noise level exceeding a certain threshold, pollution levels reaching a certain level, humidity reaching a certain level, or any other ambient factors. Triggers may include times of day, e.g., the time is 4 PM. Various embodiments contemplate that any suitable trigger for an advertisem*nt may be used.
In various embodiments, limits field 3312 may store limits or constraints on when an ad may or must be presented, or under what circ*mstances an ad may be presented. For example, a limit may specify that no more than one thousand ads per day are to be presented across all users. As another example, a limit may specify that a maximum of two of the same advertisem*nts may be presented to a given user. As another example, a constraint may specify that an ad should not be presented between the hours of 11 p.m. and 8 a.m. Another constraint may specify that an ad should not be presented when a mouse is in use (e.g., the ad may be intended for presentation on the mouse, and it may be more likely that the ad is seen if the user is not already using the mouse for something else). Various embodiments contemplate that any suitable constraints on the presentation of an advertisem*nt may be specified. Presenting devices field 3314 may indicate which types of devices (e.g., which types of peripheral devices, e.g., which types of user devices), and/or which combination of types of devices, should be used for presenting an advertisem*nt. Example presenting devices may include: a keyboard; a mouse; a PC with mouse; a tablet; a headset; a presentation remote; an article of digital clothing; smart glasses; a smartphone; or any other device; or any other device combination. Modality(ies) field 3316 may indicate the modalities with which an advertisem*nt may or must be presented. Example modalities may include video; tactile; video and LED; image and tactile; heating, or any other modality or combination of modalities. In various embodiments, when an advertisem*nt is presented, it is presented simultaneously using multiple modalities. For example, a video of a roller coaster may be displayed while a mouse simultaneously rumbles. As another example, an image of a relaxing ocean resort may be presented while a speaker simultaneously outputs a cacophony of horns honking (as if to say, “get away from the noise”). Ad content field 3318 may store the actual content of an advertisem*nt. Such content may include video data, audio data, tactile data, instructions for activating lights built into peripheral devices or user devices, instructions for activating heating elements, instructions for releasing fragrances, or any other content or instructions.
Referring to
Referring to
For example, central controller 110 may wish to estimate a user's skill level at a video game based on just a few minutes of play (this may allow the central controller, for example, to adjust the difficulty of the game). Initially, the central controller may gather data about users' actions within the first few minutes of the video game, as well as the final score achieved by the users in the game. Based on this set of data, the central controller may train a model that predicts a user's final score in a game based on the user's actions in the first few minutes of the game. The predicted final score may be used as a proxy for the user's skill level. As another example, a central controller may wish to determine a user's receptivity to an advertisem*nt based on the motions of the user's head while the user views the advertisem*nt. Initially, the central controller 110 may gather data from users who watch an advertisem*nt and subsequently either click the advertisem*nt or ignore the advertisem*nt. The central controller may record users' head motions while they watch the advertisem*nt. The central controller may then train a model to predict, based on the head motions, the chance that the user will click the advertisem*nt. This may allow the central controller, for example, to cut short the presentation of an ad if it is clear that the user is not receptive to the ad.
AI Model ID field 3502 may store an identifier (e.g., a unique identifier) for an AI model. Model type field 3504 may store an indication of the type of model. Example model types may include ‘linear regression’, ‘2nd degree polynomial regression’, ‘neural network’, deep learning, backpropagation, and so on. Model types may be specified in terms of any desired degree of specificity (e.g., the number of layers in a neural network, the type of neurons, the values of different hyperparameters, etc.). ‘X’ data source field 3506 may store information about the input data that goes into the model. Field 3506 may indicate the source of the data, the location of the data, or may store the data itself, for example. Example input data may include game scores after the first five minutes of play for game gm14821, or the content of team messages passed for game gm94813. ‘Y’ data source field 3508 may store information about the data that is intended to be predicted by the model. This may also be data that is used to train the model, to validate the model, or to test the model. Field 3508 may indicate the source of the data, the location of the data, or may store the data itself, for example. Example output data may include final game scores for game gm14821, or final team scores for game gm94813. For example, a team's final score may be predicted based on the content of the messages that are being passed back and forth between team members. This may help to determine whether a team can improve its methods of communication.
Parameter Values field 3510 may store the values of one or more parameters that have been learned by the model, or which have otherwise been set for the model. Examples of parameters may include a slope, an intercept, or coefficients for a best fit polynomial. Accuracy field 3512 may store an indication of the accuracy of the model. The accuracy may be determined based on test data, for example. As will be appreciated, accuracy may be measured in a variety of ways. Accuracy may be measured in terms of a percentage of correct predictions, a root mean squared error, a sensitivity, a selectivity, a true positive rate, a true negative rate, or in any other suitable fashion. Last update field 3514 may store an indication of when the model was last updated. In various embodiments, the model may be retrained or otherwise updated from time to time (e.g., periodically, e.g., every day, etc.). New data that has been gathered may be used to retrain the model or to update the model. This may allow the model to adjust for changing trends or conditions. Update trigger field 3516 may store an indication of what would trigger a retraining or other update of the model. In some embodiments, a retraining is triggered by a date or time. For example, a model is retrained every day at midnight. In some embodiments, the model is retrained when a certain amount of new data has been gathered since the last retraining. For example, a model may be retrained or otherwise updated every time 1000 new data points are gathered. Various other triggers may be used for retraining or updating a model, in various embodiments. In various embodiments, a person may manually trigger the retraining of a model.
Referring to
In various embodiments, when a user is to be authenticated, the user presents information, and the information presented is compared to user information on file in table 3600. If there is a sufficient match, then it may be concluded that the user is in fact who he claims to be. In one embodiment, after a user is authenticated, the central controller 110 looks up the user in employee table 5000 (or in some embodiments user table 700) to verify that the user is clear to work with objects in a particular location. For example, one user might be cleared to use a particular chemical, but is not allowed into a room because a different chemical is present which the user is not cleared to handle. So even though the user is authenticated, they may not have the right credentials as a user for the chemical in that particular location. Examples of things that may require a level of authentication include radioactive elements, hazardous chemicals, dangerous machinery, government contracts, encryption keys, weapons, company sensitive information such as financials or secret projects, personnel information such as salary data, confined space entry, etc.
Referring to
Authentication
In various embodiments, various applications can be enhanced with authentication protocols performed by a peripheral, user device 107a, central controller 110, and/or other device. Information and cryptographic protocols can be used in communications with other users and other devices to facilitate the creation of secure communications, transfers of money, authentication of identity, and authentication of credentials. Peripheral devices could be provided to a user who needs access to sensitive areas of a company, or to sensitive information. The peripheral might be issued by the company and come with encryption and decryption keys securely stored in a data storage device of the peripheral. In various embodiments, encryption is an encoding protocol used for authenticating information to and from the peripheral device. Provided the encryption key has not been compromised, if the central controller can decrypt the encrypted communication, it is known to be authentic. Alternatively, the cryptographic technique of “one-way functions” may be used to ensure communication integrity. As used herein, a one-way function is one that outputs a unique representation of an input such that a given output is likely only to have come from its corresponding input, and such that the input can not be readily deduced from the output. Thus, the term one-way function includes hashes, message authenticity codes (MACs-keyed one-way functions), cyclic redundancy checks (CRCs), and other techniques well known to those skilled in the art. See, for example, Bruce Schneier, “Applied Cryptography,” Wiley, 1996, incorporated herein by reference. As a matter of convenience, the term “hash” will be understood to represent any of the aforementioned or other one-way functions throughout this discussion.
Tamper Evidence/Resistance
One or more databases according to various embodiments could be stored within a secure environment, such as within a secure enterprise or off-premises datacenter within locked doors and 24/7 security guards, or in a cloud computing environment managed by a third party storage/compute provider such as Google® Cloud or Amazon® Web Services. These databases could be further secured with encryption software that would render them unreadable to anyone without access to the secure decryption keys. Encryption services are commonly offered by cloud database storage services. Security could be used to protect all databases according to various embodiments, or it could be applied only to select databases—such as for the storage of user passwords, financial information, or personal information. An alternative or additional form of security could be the use of tamper evident or tamper resistant enclosures for storage devices containing databases. For example, a dedicated computer processor (e.g., processor 605) may have all of its components—including its associated memory, CPU and clock housed in a tamper-resistant and/or tamper-evident enclosure to prevent and reveal, respectively, tampering with any of these components. Tamper-evident enclosures include thermoset wraps which, upon inspection, can reveal any attempt to physically open the structure. Tamper-resistant structures may electronically destroy the memory contents of data should a player try to physically open the structure.
Devices and Interactions
With reference to
With reference to
Speakers 3909a and 3909b can broadcast sounds and audio related to games, background music, game character noises, game noises, game environmental sounds, sound files sent from another player, etc. In some embodiments, two game players can speak to each other through microphone 3920, with the sound being transmitted through microphone 3920 to memory and processor 3925 and then to central controller 110 to speakers 3915a and 3915b on the other player's keyboard 3900. Lights 3912a and 3912b can illuminate all or part of a room. In some embodiments, suitable lighting technology could include LED, fluorescent, or incandescent. In various embodiments, lights 3912a and 3912b can serve as an alerting system to get the attention of a user such as a game player or a virtual meeting attendee by flashing or gradually increasing the light's intensity. In some embodiments, one user can send a request signal to memory and processor 3920 to flash the lights 3915a and 3915b of the other user's keyboard 3900. Sensors 3915a and 3915b may include mechanical sensors, optical sensors, photo sensors, magnetic sensors, biometric sensors, or any other sensors. A sensor may generate one or more electrical signals to represent a state of a sensor, a change in state of the sensor, or any other aspect of the sensor. For example, a contact sensor may generate a “1” (e.g., a binary one, e.g., a “high” voltage) when there is contact between two surfaces, and a “0” (e.g., a binary “0”, e.g., a “low” voltage) when there is not contact between the two surfaces. A sensor may be coupled to a mechanical or physical object, and may thereby sense displacement, rotations, or other perturbations of the object. In this way, for example, a sensor may detect when a surface has been touched, when a surface has been occluded, or when any other perturbation has occurred. In various embodiments, sensors 3915a and 3915b may be coupled to memory and processor 3925, and may thereby pass information on to central controller 110 or to a room controller.
Microphone 3920 can pick up audible signals from a user as well as environmental audio from the surroundings of the user. In one embodiment, microphone 3920 is connected to memory and processor 3925. Memory and processor 3925 allows for the storage of data and processing of data. In one embodiment, memory and processor 3925 is connected to central controller 110 and can send messages to other users, receive files such as documents or presentations, store digital currencies or financial data, store employee ID numbers, store passwords, store cryptographic keys, store photos, store video, and store biometric values from the keypad and store them for processing. In various embodiments, memory and processor 3925 can communicate via wired or wireless network with central controller 110 and house controller 6305. Memory and processor 3925 may include memory such as non-volatile memory storage. In some embodiments, this storage capacity could be used to store software, user images, business files (e.g., documents, spreadsheets, presentations, instruction manuals), books (e.g., print, audio), financial data (e.g., credit card information, bank account information), digital currency (e.g., Bitcoin™), cryptographic keys, user biometrics, user passwords, names of user friends, user contact information (e.g., phone number, address, email, messaging ID, social media handles), health data (e.g., blood pressure, height, weight, cholesterol level, allergies, medicines currently being taken, age, treatments completed), security clearance levels, message logs, GPS location logs, and the like.
Various embodiments contemplate the use of diffusing fiber optics, such as optical fiber 3928 or shorter strand optical fibers 3930a, 3930b, and 3930c. These may include optical glass fibers where a light source, such as a laser, LED light, or other source is applied at one end and emitted continuously along the length of the fiber. As a consequence, the entire fiber may appear to light up. Optical fibers may be bent and otherwise formed into two or three dimensional configurations. Furthermore, light sources of different or time varying colors may be applied to the end of the optical fiber. As a result, optical fibers present an opportunity to display information such as a current state (e.g., green when someone is available and red when unavailable), or provide diverse and/or visually entertaining lighting configurations.
With reference to
In various embodiments, one of right speaker cushion 4012a or left speaker cushion 4012b includes one or more tactile dots 4035. A tactile dot may include a small elevated or protruding portion designed to make contact with the user's skin when the headset 4000 is worn. This could allow for embodiments in which processor 4055 could direct a haptic signal to alert a user via tactile dots 4035, or direct heat via heating element 4065, or provide a puff of air. As the headset may have a similar appearance from the front and from the back, a tactile dot (when felt on the appropriate side) may also serve as a confirmation to the user that the headset is facing in the proper direction. A microphone 4014 together with microphone boom 4016 may extend from base 4006b, placing the microphone in a position where it may be proximate to a user's mouth. Headset 4000 may include one or more camera units 4020. Two forward-facing cameras 4022a and 4022b are shown atop the headband 4002. In some embodiments, two such cameras may provide stereoscopic capability. An additional camera (e.g., a backward facing camera) (not shown) may lie behind camera unit 4020 and face in the opposite direction. Camera unit 4020 may also include a sensor 4024 such as a rangefinder or light sensor. Sensor 4024 may be disposed next to forward facing camera 4022a. In some embodiments, sensor 4024 may be a laser rangefinder. The rangefinder may allow the headset to determine distances to surrounding objects or features. In one embodiment, sensor 4024 includes night vision capability which can provide data to processor 4055, which can in some embodiments direct the user in gameplay to avoid danger, capture enemies, or perform other enhanced maneuvers. Camera unit 4020 may include one or more lights 4026 which can help to illuminate objects captured by forward facing cameras 4022a-b.
Buttons 4030a and 4030b, may be available to receive user inputs. Exemplary user inputs might include instructions to change the volume, instructions to activate or deactivate a camera, instructions to mute or unmute the user, or any other instructions or any other inputs. In various embodiments, headset 4000 may include one or more additional input components. In some embodiments, an extendible stalk 4028 is included to allow the camera unit 4020 to be raised to a higher level, which could allow for sampling of air quality at a higher level, for example. In some embodiments, extendible stalk 4028 may be bendable, allowing a user to position camera unit 4020 at various angles.
In various embodiments, headset 4000 may include one or more attachment structures 4037a and 4037b consisting of connector points for motion sensors, motion detectors, accelerometers, gyroscopes, and/or rangefinders. Attachment structures 4037a and 4037b may be electrically connected with processor 4055 to allow for flow of data between them. Attachment structures 4037a and 4037b could include one or more points at which a user could clip on an attachable sensor 4040. In some embodiments, standard size structures could enable the use of many available attachable sensors, enabling users to customize their headset with just the types of attachable sensors that they need for a particular function. For example, a firefighter might select several types of gas sensors to be worn on the headset, or even attach a sensor for a particular type of gas prior to entering a burning building suspected of containing that gas. In another embodiment, the attachment structures 4037a and 4037b could be located on other portions of headset 4000 such as on speakers 4010a-b or on bases 4006a-b. The attachable sensors 4040 may be used to detect a user's head motions, such as nods of the head or shaking of the head. The sensors may be used for other purposes, too. In some embodiments, a user may take a sensor from attachment structures 4037a or 4037b and clip it to their clothing (or to another user's clothing) and then later return the sensor to attachment structures 4037a or 4037b.
In various embodiments, instead of forward facing cameras 4022a-b (or instead of a backward facing camera), headset 4000 may include a 360-degree camera on top of headband 4002 within camera unit 4020. This may allow for image capture from all directions around the user. In some embodiments, microphone boom lights 4044 may be capable of illuminating the user, such as the user's face or skin or head or other body part, or the user's clothing, or the user's accessories, or some other aspect of the user. In other embodiments, headband lights 4042a and 4042b may be disposed on headband 4002, facing away from a prospective user. Such lights might have visibility to other users, for example. When activated, such lights might signal that the user has accomplished something noteworthy, that it is the user's turn to speak, that the user possesses some rank or office, or the lights may have some other significance, some aesthetic value, or some other purpose.
Display 4046 may be attached to microphone boom 4016. In various embodiments, display 4046 faces inwards towards a prospective user. This may allow a user to view graphical information that is displayed through his headset. In various embodiments, display 4046 faces outwards. In various embodiments, display 4046 is two-sided and may thereby display images both to the user and to other observers. In various embodiments, an inward facing display and an outward facing display need not be part of the same component, but rather may comprise two or more separate components. Headband display 4048 may be disposed on headband 4002, e.g., facing away from a prospective user, and may thereby display images to other observers.
Cushion sensor 4050 may be disposed on right cushion 4012a. When the headset is in use, cushion sensor 4050 may be in contact with a user's skin. The sensor may be used to determine a user's skin hydration, skin conductivity, body temperature, heart rate, or any other vital sign of the user, or any other signature of the user. In various embodiments, additional sensors may be present, such as on left cushion 4012b. Cushion sensor 4050 may be used as a haptic for feedback to the user, to impart some sensory input, which may be a buzzing, a warm spot, or any other sensory information. In various embodiments, additional sensors may be present, such as on left cushion 4012b. Cable 4052 may carry power to headset 4000. Cable 4052 may also carry signals (e.g., electronic signals, e.g., audio signals, e.g., video signals) to and from the headset 4000. Cable 4052 may terminate with connector 4054. In some embodiments, connector 4054 is a USB connector.
Terminals 4067a and 4067b may lead into speaker bases 4006a and 4006b, and may serve as an attachment point for electronic media, such as for USB thumb drives, for USB cables, or for any other type of media or cable. Terminals 4067a-b may be a means for charging headset 4000 (e.g., if headset 4000 is wireless). data storage 455 may comprise non-volatile memory storage. In some embodiments, this storage capacity could be used to store software, user images, business files (e.g., documents, spreadsheets, presentations, instruction manuals), books (e.g., print, audio), financial data (e.g., credit card information, bank account information), digital currency (e.g., Bitcoin™), cryptographic keys, user biometrics, user passwords, names of user friends, user contact information (e.g., phone number, address, email, messaging ID, social media handles), health data (e.g., blood pressure, height, weight, cholesterol level, allergies, medicines currently being taken, age, treatments completed), security clearance levels, message logs, GPS location logs, current or historical environmental data (e.g., humidity level, air pressure, temperature, ozone level, smoke level, CO2 level, CO level, chemical vapors), and the like. In various embodiments, headset 4000 includes a Bluetooth® antenna (e.g., an 8898016 series GSM antenna) (not shown). In various embodiments, headset 4000 may include any other type of antenna. In various embodiments, headset 4000 includes an earbud (not shown), which may be a component that fits in the ear (e.g., for efficient sound transmission).
Headset 4000 may also include accelerometers 4070a and 4070b which are capable of detecting the orientation of headset 4000 in all directions and the velocity of headset 4000. Such accelerometers might be used for detecting the direction of gaze of a user, speed of walking, nodding of the user's head, etc. Optical fibers 4072a and 4072b are a thin strand of diffusing optical fiber. These may include optical glass fibers where a light source, such as a laser, LED light, or other source is applied at one end and emitted continuously along the length of the fiber. As a consequence, the entire fiber may appear to light up. Optical fibers may be bent and otherwise formed into two or three dimensional configurations. Furthermore, light sources of different or time varying colors may be applied to the end of the optical fiber. As a result, optical fibers present an opportunity to display information such as a current state (e.g., red when a user is in an environment with low oxygen levels), or provide diverse and/or visually entertaining lighting configurations. In some embodiments, headset 4000 includes outward speakers 4074 which can generate a sound hearable by other users. A projector 4076 could be used to project information in front of a user. In some embodiments, projector 4076 may project text from a machine instruction manual onto a wall in front of the user. In some embodiments, a smell generator 4078 is capable of generating smells which may be used to alert the user or to calm down the user. Vibration generator 4080 may be used to generate vibrations that a user feels on the surface of cushion 4012a. Piezoelectric sensor 4082 may be attached to headband 4002 so as to detect bending of headband 4002 (e.g., detecting when a user removes or puts on a headset).
In some embodiments, a heads up display (“HUD”) (not shown) and/or “helmet mounted display” (“HMD”) (not shown) is included in headset 4000 and used to display various data and information to the wearer. In some embodiments, HUD and/or HMD capability may be incorporated into projector 4076. The HUD and/or HMD can use various technologies, including a collimator to make the image appear at an effective optical infinity, project an image on a facemask or windshield, or “draw” the image directly on the retina of the user. Some advantages of a HUD and/or HMD include allowing the user to check on various important data points while not changing their visual focus, which might be beneficial when used in aircraft and automobile embodiments. Other applications could include military settings, for motorcyclists, etc. A HUD and/or HMD may display important operational information in industrial settings, such as ambient temperatures, oxygen levels, a timer, the presence of toxic elements, or any other information or data that is needed. A HUD and/or HMD may display status information of another user, such as their heart rate, respiration rate, blood alcohol level, etc. A HUD and/or HMD may display environmental information of another user, such as oxygen level, temperature, location, presence of dangerous gasses, etc. A HUD and/or HMD may also display important information to a gamer, such as health levels, shield strength, remaining ammunition, opponent statistics, or any other relevant information. In some embodiments, a HUD and/or HMD may comprise text output such as instruction steps for fixing a machine, or text instructions for a student who is struggling with a math problem, or recipe instructions for a user baking a cake, etc. In some embodiments, a HUD and/or HMD can be utilized to present augmented reality (“AR”) images, or virtual reality (“VR”) images to the wearer. In some embodiments, a HUD and/or HMD can be used to enhance night vision, enabling the user to be more effective in industrial settings where light is low, or in gaming scenarios where night vision can aid in game play.
In some embodiments, headset 4000 may be constructed in such a way that the earpieces fit inside the ears rather than cover the ears. In these embodiments, headset 4000 is lighter and less cumbersome, and certain features, sensors, etc. are relocated. In embodiments that fit inside the ears, there is more situational awareness that is possible; this may be important in various industrial scenarios in which process noises, alerts, and emergency notifications need to be monitored for safety and/or productivity.
In various embodiments, headset 4000 may facilitate the ability to sense smoke and alert users to stop smoking. In some embodiments, sensors may be used to detect smoke and alert the user. A user may want to try and stop smoking cigarettes and need some coaching from headset 4000. A smoke sensor may be attached to connector point 4037a-b by the user or as displayed in attachable sensor example 4040. When a user lights a cigarette and smoke emits, an attachable sensor 4040 may detect the smoke, provide the information to processor 4055 and provide an alert to the user reminding them to stop smoking. This alert from the processor may be in the form of a vibration from vibration generator 4080, an audible alert saying, ‘please stop smoking, it is bad for you’ in speakers 4010a-b, or in any other forms of feedback (e.g., a buzz, beep, or chirp). Boom lights 4044 may display a color or pattern (e.g., red blinking) and/or display 4046 may provide an image to distract the user and remind the user to stop smoking (e.g., a video showing someone suffering from lung disease or a picture of their family). The alerts may be selected in advance by the user on a device (e.g., on a user device, peripheral device, personal computer, phone, etc.), loaded using network port 4060 and stored locally in data storage 4057.
In various embodiments, headset 4000 may facilitate the ability to sense smoke and provide safety warnings, with sensors used to detect smoke and alert the user or others around them. A user may be working in a warehouse or industrial setting in building 6802 with flammable substances. If a flammable substance ignites, the headset 4000 may detect the smoke and alert the user more quickly than human senses are possible. A smoke sensor may be attached to connector point 4037a-b by the user or as displayed in attachable sensor 4040. If a flammable substance ignites in an area away from the user, attachable sensor 4040 may detect the smoke, provide the information to processor 4055 and provide an alert to exit the area immediately. This alert from the processor may be in the form of a vibration from vibration generator 4080, an audible alert saying, ‘smoke detected, please exit immediately and call 9-1-1’ in speakers 4010a-b, lights 4042a-b flashing red to alert others around the user to evacuate and take the individual, boom lights 4044 on microphone boom 4016 may display a color or pattern (e.g., blinking red) and/or display 4046 may provide an image to alert the user to exit (e.g., a floor plan and path to the exit the room and building). Likewise, optical fibers 4072a-b may light up in orange for immediate visual alerts to others or emergency workers. The outward speaker 4074 may provide a high pitched burst of beeps to indicate the need to evacuate or a verbal warning that ‘smoke has been detected, please exit immediately’. Attachable sensor 4040 may detect the type of smoke (e.g., chemical, wood, or plastic) based on information stored in data storage 4057 and interpreted by processor 4055. If the smoke detected is from a chemical fire, communications to company safety teams may occur through internal satellite, Bluetooth® or other communications mechanisms within headset 4000 and housing 4008a-b to alert them to the type of fire for improved response and specific location. Projector 4076 may display a message on the wall indicating that ‘smoke has been detected and it is a chemical fire—exit immediately—proceed to the wash station’. Also, the projector 4076 may display a map of building 6802 with the nearest exit or provide on display 4046.
In various embodiments, headset 4000 may facilitate the ability to sense various gases (e.g., natural gas, carbon monoxide, sulfur, chlorine) and provide safety warnings. In some embodiments, sensors (e.g., natural gas, carbon monoxide, sulfur) may be used to detect odors or gas composition (e.g., odorless carbon monoxide) and alert the user. A user may be working in their living room where a gas fireplace is located. During the day, the pilot light may go out, but the gas remains on due to a faulty fireplace gas sensor. The user's senses become saturated to a point they no longer smell the gas posing a danger to her family. The headset 4000 may detect the natural gas and alert the user more quickly than human senses are possible. A natural gas sensor may be attached to connector point 4037a-b by the user or as displayed in attachable sensor 4040. Attachable sensor 4040 may detect the natural gas, provide the information to processor 4055 and provide an alert to the user to exit the house immediately or open the windows and doors. This alert from the processor may be in the form of a headset vibration with vibration generator 4080, an audible alert saying, ‘natural gas detected, please exit immediately and call 9-1-1’ in speaker 4010a-b and/or outward speaker 4074, boom lights 4044 may display a color or pattern (e.g., blinking red) and/or display 4046 may provide an image to alert the user to exit (e.g., a floor plan and path to the exit the room and home). The attachable sensor 4040 may be used to detect the type of gas as well (e.g., natural gas, carbon monoxide, non-lethal sulfur, chlorine) based on information saved in data storage 4057 and interpreted by processor 4055. The headset 4000 may alert the fire department, other emergency agencies or family members with headsets through the communications mechanisms (e.g., antenna, satellite, Bluetooth®, GPS) within housing 4008a-b about the gas and composition and location of the user for more rapid response.
Likewise, a research and development employee in building 6800 biohazard room 6870 may be working on an experiment to make chlorine gas. Instead of adding small amounts of concentrated hydrochloric acid to the potassium permanganate solution, the researcher adds too much hydrochloric acid, creating an unstoppable reaction and creating too much lethal chlorine gas. The headset 4000 may immediately detect elevated levels of chlorine gas through the attachable sensor 4040 based on values in data storage 4057 and interpreted by processor 4055 and immediately alerts the employee, safety teams, public emergency works and other employees. This alert sent from processor 4055 may be in the form of a buzz from cushion sensor 4050, an audible alert in speaker 4010a-b saying, ‘chlorine gas detected, please exit immediately and call 9-1-1’, boom lights 4044 or headband lights 4042a-b may display a color or pattern (e.g., blinking and solid red variation) and/or display 4046 may provide an image to alert the user to exit (e.g., a floor plan and path to the nearest exit the room). Headset 4000 may alert the fire department, other emergency agencies, local safety team members or employees in close proximity with headsets through the internal communications (e.g., antenna, satellite, Bluetooth, GPS) within housing 4008a-b about the chlorine gas for more rapid and accurate response (e.g., correct equipment to combat the chlorine gas). Alerts (e.g., chlorine gas detected in room 6870) may also be displayed on building 6802 walls using projectors 6850a-f and lights 6808a-g (e.g., red flashing) along with evacuation notices from speakers 6850a-e.
In various embodiments, headset 4000 may facilitate the ability for a user to progress through a checklist (e.g., recipe). In various embodiments, forward facing cameras 4022a-b may be able to detect steps on a checklist and assist the user. A user may store a recipe (e.g., pasta fa*gioli soup) in data storage 4057 using an electronic device (e.g., computer, phone, tablet) through network port 4060. This recipe may be interpreted by processor 4055 and stored in data storage 4057 with a unique name (e.g., pasta fa*gioli soup) for later retrieval. The user may access the recipe by speaking into microphone 4014 to request retrieval of the pasta fa*gioli soup using a voice command (e.g., ‘retrieve pasta fa*gioli recipe’). As the user is preparing the soup, the forward facing camera 4022a-b on extendible stalk 4028 may capture the movements and steps and communicate with processor 4055. The processor may determine that the user has skipped adding a dash of tabasco sauce from the recipe and informs the user through speaker 4010a-b that a step was missed and tells the user the ingredient that was left out (e.g., tabasco). Likewise, display 4046 or projector 4076 may also show the steps of the recipe and indicate they are completed (e.g., crossing through the step, checking off the step). If a step is missed or performed out of order or incorrectly as determined by forward facing camera 4022a-b and processor 4055, the headset 4000 may provide alerts such as vibrations from the vibration generator 4080, notices on display 4046 (e.g., ‘stop—a step was missed in the recipe’), boom lights 4044 may display yellow, outward speaker 4074 or speaker 4010a-b may provide verbal warnings (e.g., ‘review steps or ingredients’) of missed steps or missing ingredients. Likewise, a user may decide to by-pass the warning or message if they do not want to include the ingredient by pressing the button 4030a-b indicating to processor 4055 to skip the step or ingredient.
In various embodiments, headset 4000 may facilitate the ability to detect steps on a checklist and assist the user. A pilot or company may input the pre-flight checklist for all aircraft in the headset 4000 and save in data storage 4057 from an electronic device (e.g., computer, phone, digital tablet) through the network port 4060. The pilot, using microphone 4014, may request retrieval of the pre-flight checklist using a voice command (e.g., ‘load pre-flight checklist for MD-11’). The pre-flight checklist may be shown on display 4046 as a reminder to the pilot along with scrolling capabilities. As the pilot is performing the pre-flight check, the forward facing camera 4022a-b may capture the movements and steps of the pilot during the pre-flight activities and communicate those with processor 4055. The accelerometer 4070a-b may detect that the head movement and focus did not occur on an element of the plane referenced in the checklist. The processor detects that the pilot may have skipped checking the flaps on the right wing and may inform the pilot through speaker 4010a-b (e.g., check right wing flaps), vibration to the pilot from vibration generator 4080 to alert the pilot of a missed step, colors on microphone boom lights 4044 (e.g., solid red) and/or communication to the flight control team through communication mechanisms (e.g., Bluetooth, satellite, cellular) that a step was missed. The flight control team may communicate directly to the pilot through the headset 40000 asking her to recheck the pre-flight steps or inform the captain. Likewise, display 4046 may also show the pre-flight checklist and indicate the completed (e.g., crossing through the step, checking off the step) or missing (e.g., highlighting in bold and red) steps.
In various embodiments, headset 4000 may facilitate the ability to coach a user through steps and provide analysis. There may be situations where repeating a step is needed for ongoing improvement and coaching analysis is needed. A new basketball player may have to shoot thousands of free throws to improve their performance. Coaching after every shot may not be appropriate. The headset 4000 with cameras 4022a-b may record each free throw taken by the player during practice. After every 50 shots, processor 4055 may perform an analysis of all shots and provide a coaching summary. The analysis may be in the form of written comments on display 4046 (e.g., 45% shots made, too many dribbles before shooting, not enough arch on the ball, too long of a delay before shooting), highlights of good and poor shots displayed on a wall with projector 4076 for review by the player, verbal feedback in speaker 4010a-b providing steps for improvement or encouragement (e.g., ‘good shot’). Likewise, so as to not interrupt the player, feedback may be given to the coach or others watching. Headband lights 4042a-b may display green when processor 4055 determines the technique in shooting was performed well or red when improvements are needed. The coach observing the player may immediately see the lights and determine if they should stop the player and provide more coaching or encouragement.
In various embodiments, headset 4000 may facilitate the ability to coach or provide feedback to users regarding verification of performed steps. In some embodiments, a user may need to understand what steps of a process were missed for training purposes, but interruption during the process is not desired. A factory worker may be required to assemble small components on a computer board. The user may have been trained and now the employer needs to verify they can successfully complete the steps. The user wearing a headset 4000 begins to assemble the computer board. The forward facing cameras 4022a-b may record each step of assembly along with the duration of each step and communicate this information to processor 4055 and data storage 4057. Once the assembly is completed, processor 4055 may review the steps for accuracy and time and inform the user. The feedback may be through display 4046 or projector 4076 on a wall that a step was missed and/or the time to complete specific steps took too long (e.g., step 3 took 30 seconds and only 15 seconds is allocated). The user may make the necessary corrections and perform the steps again with headset 4000 until there are no missed assembly steps and the time to perform the steps are within an acceptable range. Likewise, when all steps are performed correctly and within an acceptable time, headband lights 4042a-b, lights 4026 or optical fibers 4072a-b may light up (e.g., solid green) to indicate to the supervisor that there are no issues. The factory worker may also get notification through boom lights 4044 (e.g., green) or display 4046 (e.g., “OK—great work”) that there are no performance issues.
In various embodiments, headset 4000 may facilitate the ability to capture records of completing checklist items for later recall. In some embodiments, there may be situations where a user needs to recall specific actions performed as proof that there were no deficiencies. In a manufacturing room 6885 where chemical cleaning occurs on parts, it may be necessary to provide evidence that a part was cleaned according to specific instructions and steps to defend the company's actions in court or appease an upset customer. Using headset 4000, forward facing cameras 4022a-b may record the actions of a user cleaning parts in the chemical room with acid tanks 6885. The forward facing cameras record the specific part by reading the part measurements, barcode or image. The processor 4055 compares measurements or images to stored parts in data storage 4057 to retrieve the checklist or procedures for the specific part. While the user is cleaning the part, the forward facing cameras capture the video of the item, date, time, and procedures performed according to the documented checklist. This information may be stored in data storage 4057 for uploading to company databases from network port 4060 or other communications capabilities in housing 4008a-b (e.g., Bluetooth®, satellite, USB connection). In some embodiments, the information stored in data storage 4057 may be used as an audit trail which can be provided to company auditors, regulators, safety inspectors, etc. In various embodiments, a company may use information stored in data storage 4057 to prove in court that a part number was cleaned properly. The company may retrieve the part number and actions that were performed on the part to defend themselves in court. Likewise, they may retrieve all video of the part cleaning process to defend their standard operating procedure.
In various embodiments, headset 4000 may facilitate the ability to include a checklist with criteria that can be verified by eye gaze/head/body orientation. In some embodiments there may be situations where assembly line workers are needed to visually inspect items for quality control. An automobile manufacturer may require a visual inspection of final painted vehicles for scratches or paint flaws. The employee with a headset 4000 and forward facing cameras 4022a-b may inspect the automobiles coming off the assembly line. Accelerometers 4070a-b may be used to monitor eye gaze time and head movements to validate that a user is actually looking at the exterior of the automobile for defects and not in other locations. If the camera or accelerometer detects the user gazing in a direction other than the automobile, vibration from vibration generator 4080 may occur to alert the user to pay attention, a tone in speaker 4010a-b may occur (e.g., short chirping sound), headband lights 4042a-b may flash orange giving the supervisor and opportunity to coach the employee to pay more attention or the display 4046 may show a message to the worker to look in the direction of the automobile. Boom lights 4044 may also blink in red to alert the worker to pay attention.
In various embodiments, headset 4000 may provide an opportunity for another person to observe an action such as in industrial settings, construction, healthcare, fast food and the like without physically being in the room. In healthcare environments where highly contagious or seriously ill people require limited contact, it may be necessary for other medical professionals to assess the patient through the eyes of only one person in the room. A person suffering from meningitis may have a doctor with headset 4000 evaluate their condition while other physicians observe in remote locations. As this is a highly contagious disease, other doctors may want to evaluate them without entering the room. The forward facing cameras 4022a-b may record in the direction the physician is looking at the patient. The physician may dictate through microphone 4014 to turn on lights 4026 so she can evaluate the dilation of the eyes. A doctor watching in a remote location through the eyes of the on-site physician may notice a slow dilation response and ask the doctor in the room to perform a different alertness assessment. The physician may decide to prescribe a new drug and speak into microphone 4014 and show the dosage and drug interactions on display 4046 before writing the prescription. Later, the physician may want to perform a new evaluation technique but needs to see the exact process. Projector 4076 displays on the wall behind the patient the steps and video of the procedure before the doctor performs the evaluation. In some embodiments, evaluation of hearing may take place by having the physician request audible sounds be delivered from outward speaker 4074 so the patient can respond (e.g., hold up your hand if you hear a tone). The overall evaluation may be recorded by cameras 4022a-b and stored in data storage 4057 for future reference and training of interns.
In various embodiments, headsets may facilitate good cleaning practices. Office cleaning may become more important to remove germs and create a safe work environment. In some embodiments, maintenance personnel with headset 4000 may be instructed to spray the desk, wait for 30 seconds and wipe until dry, spending a minimum of 2 minutes per desk to ensure a safe work environment. During cleaning, forward facing cameras 4022a-b may collect the desk cleaning activities of the maintenance worker, send a record to processor 4055 for evaluation against standards and store the results in data storage 4057. The processor determines that in one situation cleaning spray was not applied and the speaker 4010a-b may alert the user to reclean the desk and apply a cleaning solution. The processor may also determine that desks are only being cleaned an average of 1 minute 30 seconds, not the required 2 minutes. Cushion sensor 4050 may provide a haptic response to the worker (e.g., buzz), while display 4046 reminds the worker with a message to clean each desk for 2 minutes and to redo the cleaning, and microphone boom lights flash in multi-colors indicating the worker should reclean the surface. In some embodiments, this information may be sent from data storage 4057 by internal communications (e.g., Bluetooth®, satellite, cellular) in housing 4008a-b to the company facility and maintenance team databases for evaluation. This information may be reviewed with the cleaning company for improvement and compliance. Likewise, when employees approach their desk each day and don a headset 4000, the piezoelectric sensor 4082 may recognize the person is putting on a headset. Forward facing camera 4022a-b or GPS in the housing 4008a-b recognizes the specific desk and location. In some embodiments, processor 4055 may retrieve data from the company database and provide information regarding the cleaning status to display 4046 (e.g., all cleaned) and/or microphone boom lights 4044 (e.g., display solid green for cleaned desk or red for unclean desk) to the employee. Likewise, the employee may be presented with a brief video on display 4046 showing successful cleaning the night before indicating it is safe to sit and begin work.
With reference to
With reference to
With reference to
In various embodiments, a headset 400 (not shown) includes functionality of a barcode reader, and is thereby able to read and interpret instructions represented by a barcode. For example, headset 4000 may include a camera, laser, light, or other optical element in order to read barcodes. In various embodiments, a mouse pad may incorporate or embed instructions using other means. For example, a mouse pad may incorporate RFID chips, NFC chips, proximity chips, or the like, which may trigger an instruction for the headset when the headset is nearby. In various embodiments, form factors besides a mouse pad may incorporate barcodes, proximity chips, or any other device for triggering instructions. In various embodiments, peripheral devices other than a mouse may detect and/or respond to barcodes, proximity chips, or the like.
With reference to
The circuit completion can be detected by a logic gate bridging the two particular wires that are now in electrical communication. For example, an “AND” gate is connected at one input to the positive voltage supply (e.g., via wire 4312a), and at the other input (e.g., via wire 4312b), through a resistor, to ground. Normally, with only one input connected to the positive voltage supply (i.e., to logic “1”), the AND gate will output a “0” signal. However, when movable conductor 4302 bridges the two wires connecting to the respective inputs of the AND gate, both inputs will now be logically positive, and the AND gate will output a “1” signal. Depending on which AND gate outputs a logical “1” at any given time, it may be determined which two wires are being bridged by the movable conductor 4302. In various embodiments, other methods (e.g., other logic gates, etc.) may be used to determine which wires are bridged at any given time.
By sequentially detecting which wires are being bridged, a trajectory (or some information about a trajectory) of movable conductor 4302 may be inferred. Since movable conductor 4302 is under the influence of gravity, it may thereby be inferred how the headset has moved so as to change the relative location of movable conductor 4302 within capsule 4308. For example, if movable conductor 4302 is detected bridging wires 4312a and 4312b, it may be inferred that such wires are closest to the physical ground at the moment. In various embodiments, headset 4300 may contain multiple capsules, each with wires in different orientations relative to one another. In this way, for example, more precise positioning information may be obtained.
In various embodiments, repeatedly sampled position information from one or more sensors such as sensor 4301 may be differentiated to obtain velocity information, and may be twice differentiated to obtain acceleration information.
As will be appreciated, sensor 4301 represents a method of obtaining motion data according to some embodiments, but any suitable sensor or sensors may be used in various embodiments.
Motion sensor 4301 and other motion sensors may be found in U.S. Pat. No. 8,315,876, entitled “Headset wearer identity authentication with voice print or speech recognition” to Reuss issued Nov. 20, 2012, at columns 7-9, which is hereby incorporated by reference.
With reference to
With reference to
With reference to
In some embodiments, a user such as a machine technician is tasked with completing a checklist 4635 of items relating to status indicators of status board 4605. Status board includes indicator of battery life 4610, air pressure 4615, engine status 4620, and temperature 4625. Many more or fewer status indicators may be included on status board 4605. In some embodiments, status indicators are located on or near various machines so that the user may have to walk around in order to read the current status and mark them off as checked on checklist 4635. In some embodiments, supervisory personnel may wish to ensure that the user is diligently checking all required status indicators rather than simply checking them all off without looking at them in order to quickly complete checklist 4635, which could result in critical status updates not being identified—which could create dangerous conditions for employees or expensive breakdowns of machinery and result in halted machine output.
In various embodiments, a user headset 4630 may track the head movements of the user with accelerometers and a processor (not shown) compares the expected head movement with the actual movement. For example, once the user checks off that he has read the battery life 4610 indicator, the processor of headset 4630 may expect to see the user turn his head to the right in order to read the next status on checklist 4635 which is engine status 4620. If the user in fact makes no movement of his head to the right, the processor may send a signal to central controller 110 to alert a supervisor who can intervene to see if there is a problem with the employee completing the checklist 4635.
In some embodiments, central controller 110 may receive a video feed from the user's headset 4630 and direct the user to view particular machine status indicators, obviating the need for a checklist document to be created as the video feed from the user could be read by central controller 110 to determine the status indicator values.
With reference to
In various embodiments, the app allows an observer to configure one or more parameters of a headset. In some embodiments, the app may allow an observer to select one of the sensors worn by subject 4705 to be the priority one sensor 4720, in this case the observer has selected oxygen level as the top priority.
With reference to
At 4804, the user may select one or more other users or parties that may be associated with the mouse. These users may have the ability to send messages to the mouse, receive messages from the mouse, take control of the mouse, alter the function of the mouse, be on the same team as the owner of the mouse, combine inputs of the mouse with inputs from their own mouse or peripheral, or have any other relationship or any other association with the mouse. In various embodiments, for each user selected, the user may configure individual abilities or privileges (e.g., such as with a sub-menu for each selected user). At 4806, the user may designate a default image for the mouse (e.g., to be displayed on a display screen of the mouse). At 4808, the user may indicate default text that is to appear on the mouse. In various embodiments, a user may configure one or more other aspects of the mouse. In various embodiments, a user may configure special key combinations (e.g., hotkeys; e.g., short cuts) on the mouse, and match them to what the effects will be in the corresponding app. In various embodiments, parameters for configuration may be presented in any suitable order or arrangement. There may be multiple screens, multiple windows, multiple tabs, selections that become visible when scrolling down a page, etc. While screen 4800 has been depicted with respect to a mouse, various embodiments contemplate that similar screens could be used for other peripheral devices.
With reference to
Methods
Referring now to
The process diagrams and flow diagrams described herein do not necessarily imply a fixed order to any depicted actions, steps, and/or procedures, and embodiments may generally be performed in any order that is practicable unless otherwise and specifically noted. While the order of actions, steps, and/or procedures described herein is generally not fixed, in some embodiments, actions, steps, and/or procedures may be specifically performed in the order listed, depicted, and/or described and/or may be performed in response to any previously listed, depicted, and/or described action, step, and/or procedure. Any of the processes and methods described herein may be performed and/or facilitated by hardware, software (including microcode), firmware, or any combination thereof. For example, a storage medium (e.g., a hard disk, Random Access Memory (RAM) device, cache memory device, Universal Serial Bus (USB) mass storage device, and/or Digital Video Disk (DVD); e.g., the data storage devices 215, 345, 445, 515, 615) may store thereon instructions that when executed by a machine (such as a computerized processor) result in performance according to any one or more of the embodiments described herein. According to some embodiments, the method 8600 may comprise various functional modules, routines, and/or procedures, such as one or more AI-based algorithm executions.
Games
A process 8600 for conducting a game with a user participating in the game is now described according to some embodiments. At step 8603, a user may register with the central controller 110, according to some embodiments. The user may access the central controller 110 by visiting a website associated with the central controller, by utilizing an app that communicates with the central controller 110, by engaging in an interactive chat with the central controller (e.g., with a chatbot associated with the central controller), by speaking with a human representative of the central controller (e.g., over the phone) or in any other fashion. The aforementioned means of accessing the central controller may be utilized at step 8603 and/or during any other step and/or in conjunction with any other embodiments. Using the example of a website, the user may type into one or more text entry boxes, check one or more boxes, adjust one or more slider bars, or provide information via any other means. Using an example of an app, a user may supply information by entering text, speaking text, transferring stored information from a smartphone, or in any other fashion. As will be appreciated, the user may supply information in any suitable fashion, such as in a way that is consistent with the means of accessing the central controller 110. The user may provide such information as a name, password, preferred nickname, contact information, address, email address, phone number, demographic information, birthdate, age, occupation, income level, marital status, home ownership status, citizenship, gender, race, number of children, or any other information. The user may provide financial account information, such as a credit card number, debit card number, bank account number, checking account number, PayPal account identifier, Venmo account identifier or any other financial account information.
In some embodiments, the user may create or establish a financial account with the central controller 110. The user may accomplish this, for example, by transferring funds from an external account (e.g., from a Venmo® account) to the central controller 110, at which point the transferred funds may create a positive balance for the user in the new account. In some embodiments, the user may provide information about one or more preferences. Preferences may relate to one or more activities, such as playing games, learning, professional development, interacting with others, participating in meetings, or doing any other activities. In the context of a game, for example, preferences may include a preferred game, a preferred time to play, a preferred character, a preferred avatar, a preferred game configuration, or any other preferences. In the context of learning, preferences may include a preferred learning format (e.g., lecture or textbook or tutorial, etc.; e.g., visual versus aural; e.g., spaced sessions versus single crash course; etc.), a subject of interest, a current knowledge level, an expertise level in prerequisite fields, or any other preferences. In various embodiments, a user may provide preferences as to desired products or services. These preferences may, for example, guide the central controller in communicating advertisem*nts or other promotions to the user. In various embodiments, preferences may include preferences regarding any field or activity.
The central controller 110 may store user information and user preferences, such as in user table 700, user game profiles table 2700, and/or in any other table or data structure. In various embodiments, a user may provide biometric or other identifying or other authenticating information to the central controller 110. Such information may include, photographs of the user, fingerprints, voiceprints, retinal scans, typing patterns, or any other information. When a user subsequently interacts with the central controller 110, the user may supply such information a second time, at which point the central controller may compare the new information to the existing information on file to make sure that the current user is the same user that registered previously. Biometric or other authenticating information may be stored by the central controller in a table, such as in authentication table 3600. Further details on how biometrics can be used for authentication can be found in U.S. Pat. No. 7,212,655, entitled “Fingerprint verification system” to Tumey, et a. issued May 1, 2007, at columns 4-7, which is hereby incorporated by reference.
At step 8606, a user may register a peripheral device with the central controller 110, according to some embodiments. Through the process of registering a peripheral device, the central controller may be made aware of the presence of the peripheral device, the fact that the peripheral device belongs to (or is otherwise associated with) the user, and the capabilities of the peripheral device. The user may also provide to the central controller one or more permissions as to how the central controller may interact with the peripheral device. The user may provide any other information pertinent to a peripheral device. In various embodiments, registering a peripheral device may be performed partly or fully automatically (e.g., the peripheral device may upload information about its capabilities automatically to the central controller 110). The user may provide information about the peripheral itself, such as type, the manufacturer, the model, the brand, the year of manufacture, etc. The user may provide specifications for the peripheral. These specifications may indicate what buttons, keys, wheels, dials, sensors, cameras, or other components the peripheral possesses. Specifications may include the quantities of various components (e.g., a mouse may have two or three buttons; e.g., a mouse may have one, two, or more LED lights; e.g., a camera peripheral may have one, two, three, etc., cameras). Specifications may include the capabilities of a given component. For example, a specification may indicate the resolution of a camera, the sensitivity of a mouse button, the size of a display screen, or any other capability, or any other functionality.
In various embodiments, the central controller 110 may obtain one or more specifications automatically. For example, once given information about the model of a peripheral, the central controller may access a stored table or other data structure that associates peripheral models with peripheral specifications. In various embodiments, information about a peripheral may be stored in a table, such as in peripheral device table 1000. Any information stored in peripheral device table 1000 may be obtained from a user, may be obtained automatically from a peripheral, or may be obtained in any other fashion. In various environments, a user may provide the central controller with guidelines, permissions, or the like for interacting with the peripheral device. Permissions may include permissions for monitoring inputs received at the peripheral device. Inputs may include active inputs, such as button presses, key presses, touches, mouse motions, text entered, intentional voice commands, or any other active inputs. Inputs may include passive inputs (e.g., inputs supplied unconsciously or passively by the user), such as a camera image, a camera feed (e.g., a camera feed of the user), an audio feed, a biometric, a heart rate, a breathing rate, a skin temperature, a pressure (e.g., a resting hand pressure), a glucose level, a metabolite level, or any other passive input.
In some embodiments, separate permissions may be granted for separate types of inputs. In some embodiments, a global permission may be granted for all types of inputs. In some embodiments, a global permission may be granted while certain exceptions are also noted (e.g., the central controller is permitted to monitor all inputs except for heart rate). In various embodiments, permissions may pertain to how the central controller may use the information (e.g., the information can be used for adjusting the difficulty but not for selecting advertisem*nts). In various embodiments, permissions may pertain to how long the central controller can store the information (e.g., the central controller is permitted to store information only for 24 hours). In various embodiments, permissions may pertain to what other entities may access the information (e.g., only that user's doctor may access the information). In various environments, the user may grant permissions to the central controller to output at or via the peripheral.
The user may indicate what components of the peripheral device may be used for output. For example, a mouse might have a display and a heating element. The user may grant permission to output text on the display, but not to activate the heating element. With reference to a given component, the user may indicate the manner in which an output can be made. For example, the user may indicate that a speaker may output at no more than 30 decibels, a text message on a screen may be no more than 50 characters, or any other restriction. The user may indicate when the central controller 110 may output via the peripheral (e.g., only during weekends; e.g., only between 9 p.m. and 11 p.m.). The user may indicate circ*mstances under which an output may be made on a peripheral. For example an output may be made only when a user is playing a particular type of game. This may ensure, for example, that the user is not bombarded with messages when he is trying to work.
In various embodiments, a user may indicate what other users or what other entities may originate a message or content that is output on the peripheral. For example, the user may have a group of friends or teammates that are granted permission to send messages that are then output on the user's peripheral device. A user may also grant permission to a content provider, an advertiser, a celebrity, or any other entity desired by the user. In various embodiments, a user may indicate what other users or entities may activate components of a peripheral device, such as triggering a heating element. In various embodiments, a user may grant permissions for one or more other users to take control of the peripheral device. Permission may be granted to take full control, or partial control. When a second user takes control of a first user's peripheral device, the second user may cause the peripheral device to transmit one or more signals (e.g., signals that control the movements or actions of a game character; e.g., signals that control the progression of slides in a slide presentation; e.g., signals that control the position of a cursor on a display screen).
It may be desirable to allow a second user to control the peripheral device of a first user under various circ*mstances. For instance, the second user may be demonstrating a technique for controlling a game character. As another example, the second user may be indicating a particular place on a display screen to which he wishes to call the attention of the first user (e.g., to a particular cell in a spreadsheet). In various embodiments, a user may indicate times and/or circ*mstances under which another user may take control of his peripheral device. For example, another user may only control a given user's peripheral device when they are on the same team playing a video game. Permissions for another user or a third-party to control a peripheral device may be stored in a table, such as in peripheral configuration table 1100 (e.g., in field 1110). Aforementioned steps (e.g., granting of permission) have been described in conjunction with a registration process. However, it will be appreciated that in various embodiments, the aforementioned steps may be performed at any suitable time and/or may be updated at any suitable time. For example, at any given time a user may update a list of other users that are permitted to control the user's peripheral device. In various embodiments, a registration process may include more or fewer steps or items than the aforementioned.
At step 8609, a user may configure a peripheral device, according to some embodiments. The user may configure such aspects as the operation of the peripheral device, what key sequences will accomplish what actions, the appearance of the device, and restrictions or parental controls that are placed on the device. With regard to the operation of the peripheral device, the user may configure one or more operating variables. These may include variables governing a mouse speed, a mouse acceleration, the sensitivity of one or more buttons or keys (e.g., on a mouse or keyboard), the resolution at which video will be recorded by a camera, the amount of noise cancellation to be used in a microphone, or any other operating characteristic. Operating characteristics may be stored in a table, such as in peripheral configuration table 1100. In various embodiments, a user may configure input sequences, such as key sequences (e.g., shortcut key sequences). These sequences may involve any user input or combination of user inputs. Sequences may involve keys, scroll wheels, touch pads, mouse motions, head motions (as with a headset), hand motions (e.g., as captured by a camera) or any other user input. The user may specify such sequences using explicit descriptions (e.g., by specifying text descriptions in the user interface of a program or app, such as “left mouse button-right mouse button”), by checking boxes in an app (e.g., where each box corresponds to a user input), by actually performing the user input sequence one or more times (e.g., on the actual peripheral), or in any other fashion. For a given input sequence, a user may specify one or more associated actions. Actions may include, for example, “reload”, “shoot five times”, “copy formula” (e.g., in a spreadsheet), send a particular message to another user, or any other action. In various embodiments, an action may be an action of the peripheral itself. For example, pressing the right mouse button three times may be equivalent to the action of physically moving the mouse three feet to the right.
In various embodiments, a user may specify a sequence of actions that corresponds to an input sequence. For example, if the user scrolls a mouse wheel up and then down quickly, then a game character will reload and shoot five times in a row. A sequence of actions triggered by a user input may be referred to as a “macro”. A macro may allow a user to accomplish a relatively cumbersome or complex maneuver with minimal input required. In some embodiments, a peripheral device (or other device) may record a user's actions or activities in a live scenario (e.g., as the user is playing a live video game; e.g., as the user is editing a document). The recording may include multiple individual inputs by the user (e.g., multiple mouse movements, multiple key presses, etc.). These multiple inputs by the user may be consolidated into a macro. Thus in the future, for example, the user may repeat a similar set of multiple inputs, but now using a shortcut input. Configuration of user input sequences may be stored in a table, such as in table “mapping of user input to an action/message” 2600.
In various embodiments, a user may configure the appearance of a peripheral device.
The appearance may include a default or background image that will appear on the device (e.g., on a screen of the device). The appearance may include a color or intensity of one or more lights on the peripheral device. For example, LED lights on a keyboard may be configured to shine in blue light by default. The appearance may include a dynamic setting. For example, a display screen on a peripheral may show a short video clip over and over, or lights may cycle between several colors. An appearance may include a physical configuration. For example, a camera is configured to point in a particular direction, a keyboard is configured to tilt at a certain angle, or any other physical configuration. As will be appreciated, various embodiments contemplate other configurations of an appearance of a peripheral device. In various embodiments, a user may configure a “footprint” or other marker of a peripheral device. For example, the user may configure a mouse pointer as it appears on a user device (e.g., on a personal computer). In various embodiments, a configuration of an appearance may be stored in a table, such as in “peripheral configuration table” 1100. In various embodiments, a user may configure restrictions, locks, parental controls, or other safeguards on the use of a peripheral.
Restrictions may refer to certain programs, apps, web pages, Facebook® pages, video games, or other content. When an attempt is made to use a peripheral in conjunction with restricted content, the functionality of the peripheral may be reduced or eliminated. For example, if a user attempts to click on a link on a particular web page (e.g., a web page with restricted content), then the user's mouse button may not register the user's click. In various embodiments, restrictions may pertain to the motion or other usage of the peripheral device itself. A restriction may dictate that a peripheral device cannot be moved at more than a certain velocity, cannot be moved more than a certain distance, cannot be in continuous motion for more than some predetermined amount of time, cannot output sound above a particular volume, cannot flash lights at a particular range of frequencies (e.g., at 5 to 30 hertz), or any other restriction. Such restrictions may, for example, seek to avoid injury or other harm to the user of the peripheral, or to the surrounding environment. For example, a parent may wish to avoid having a child shake a peripheral too violently while in the vicinity of a fragile crystal chandelier. In various embodiments, a peripheral may identify its current user. For example, the peripheral may identify whether an adult in a house is using a peripheral, or whether a child in a house is using the peripheral. A peripheral may explicitly ask for identification (or some means of ascertaining identification, such as a password unique to each user), or the peripheral may identify a user in some other fashion (e.g., via a biometric signature, via a usage pattern, or in any other fashion).
In various embodiments, a peripheral may require authentication for a user to use the peripheral. For example, the peripheral may require a password, fingerprint, voiceprint or other authentication. In various embodiments, restrictions or parental controls may apply to individual users. For example, only the child in a particular house is restricted from accessing certain web content or video games. In this way, after identifying a user, a peripheral may implement or enforce restrictions only if such restrictions apply to the identified user. In various embodiments, a peripheral device may not function at all with one or more users (e.g., with any user other than its owner). This may, for example, discourage someone from taking or stealing another user's peripheral. In various embodiments, a user designates restricted content by checking boxes corresponding to the content (e.g., boxes next to a description or image of the content), by providing links or domain names for the restricted content, by designating a category of content (e.g., all content rated as “violent” by a third-party rating agency; e.g., all content rated R or higher) or in any other fashion. A user may designate one or more users to which restrictions apply by entering names or other identifying information for such users, by checking a box corresponding to the user, or in any other fashion. In various embodiments, a user may set up restrictions using an app (e.g., an app associated with the central controller 110), program, web page, or in any other fashion.
At step 8612, a user may register for a game, according to some embodiments. The user may identify a game title, a time to play, a game level, a league or other desired level of competition (e.g., an amateur league), a mission, a starting point, a stadium or arena (e.g., for a sports game), a time limit on the game, one or more peripheral devices he will be using (e.g., mouse and keyboard; e.g., game console controller), a user device he will be using (e.g., a personal computer; e.g., a game console; e.g., an Xbox), a character, a set of resources (e.g., an amount of ammunition to start with; e.g., a weapon to start with), a privacy level (e.g., whether or not the game can be shown to others; e.g., the categories of people who can view the game play), or any other item pertinent to the game. In various embodiments, a user may sign a consent form permitting one or more aspects of the user's game, character, likeness, gameplay, etc. to be shown, shared, broadcast or otherwise made available to others. In various embodiments, a user may pay an entry fee for a game. The user may pay in any suitable fashion, such as using cash, game currency, pledges of cash, commitments to do one or more tasks (e.g., to visit a sponsor's website), or in any other form.
In various embodiments, a user may register one or more team members, one or more opponents, one or more judges, one or more audience members, or any other participant(s). For example, the user may provide names, screen names, or any other identifying information for the other participants. In various embodiments, a user may designate a team identifier (e.g., a team name). One or more other users may then register and indicate that they are to be part of that team. Similarly, in various embodiments, a user may designate a game. Subsequently, one or more other users may then register and indicate that ta are to be part of that game. Various embodiments contemplate that multiple participants may register for the same team or same game in any suitable fashion. In various embodiments, user information provided when registering with the central controller, when registering for a game, or provided at any other time or in any other fashion, may be stored in one or more tables such as in “user game profiles” table 2700. In various embodiments, when a user has registered for a game, the user may be provided with messages, teasers, reminders, or any other previews of the game. In various embodiments, a peripheral device may show a timer or clock that counts down the time remaining until the game starts. In various embodiments, a peripheral device may change colors as game time approaches. For example, the peripheral device might change from displaying a green color to displaying a red color when there are less than five minutes remaining until game time. In various embodiments, a peripheral may sound an alarm when a game is about to start.
In the lead-up to a game (or at any other time) a user may take a tutorial. The tutorial may explain how to play a game, how to efficiently play a game, how to execute one or more actions during a game, how to use a peripheral effectively during a game, or may cover any other task or subject. In various embodiments, one or more components of a peripheral will attempt to draw a user's attention during a tutorial. For example, a key or a button may blink, light up, or change color. In another example, a button may heat up or create a haptic sensation. The intention may be for the user to press or actuate whatever component is drawing attention. For example, if the tutorial is teaching a user to press a series of buttons in succession, then the buttons may light up in the order of which they should be pressed. Once the user presses a first button that has been lit, the first button may go off and a second button may light up indicating that it too should be pressed. In various environments, a tutorial uses a combination of text or visual instruction, in conjunction with hands-on actuation of peripheral device components by the user. The text or visual instruction may be delivered via a user device, via a peripheral device (e.g., via the same peripheral device that the user is actuating), or via any other means.
At step 8615, a user may initiate a game, according to some embodiments. In various embodiments, the game starts based on a predetermined schedule (e.g., the game was scheduled to start at 3 p.m., and does in fact start at 3 p.m.). In various embodiments, the user manually initiates gameplay (e.g., by clicking “start”, etc.). When a user begins playing, any team members, opponents, judges, referees, audience members, sponsors, or other participants may also commence their participation in the game. In various embodiments, a user may join a game that has been initiated by another user. For example, the user may join as a teammate to the initiating user or as some other participant.
At step 8618, the central controller 110 may track user gameplay, according to some embodiments. The central controller 110 may track one or more of: peripheral device use; game moves, decisions, tactics, and/or strategies; vital readings (e.g., heart rate, blood pressure, etc.); team interactions; ambient conditions (e.g., dog barking in the background; local weather); or any other information. In various embodiments, the central controller 110 may track peripheral device activity or use. This may include button presses, key presses, clicks, double clicks, mouse motions, head motions, hand motions, motions of any other body part, directions moved, directions turned, speed moved, distance moved, wheels turned (e.g., scroll wheels turned), swipes (e.g., on a trackpad), voice commands spoken, text commands entered, messages sent, or any other peripheral device interaction, or any combination of such interactions. The peripheral device activity may be stored in a table, such as in ‘peripheral activity log’ table 2200. Each activity or action of the peripheral device may receive a timestamp (e.g., see fields 2206 and 2208). In this way, for example, peripheral device activity may be associated with other circ*mstances that were transpiring at the same time. For example, a click of a mouse button can be associated with a particular game state that was in effect at the same time, and thus it may be ascertainable what a user was trying to accomplish with the click of the mouse (e.g., the user was trying to pick up a medicine bag in the game).
Peripheral device activities may be stored in terms of raw signals received from the peripheral device (e.g., bit streams), higher-level interpretations of signals received from the peripheral device (e.g., left button clicked), or in any other suitable fashion. In various embodiments, two or more actions of a peripheral device may be grouped or combined and stored as a single aggregate action. For example, a series of small mouse movements may be stored as an aggregate movement which is the vector sum of the small mouse movements. In various embodiments, the central controller may track vital readings or other biometric readings. Readings may include heart rate, breathing rate, brain waves, skin conductivity, body temperature, glucose levels, other metabolite levels, muscle tension, pupil dilation, breath oxygen levels, or any other readings. These may be tracked, for example, through sensors in a peripheral device. Vital readings may also be tracked indirectly, such as via video feed (e.g., heart rate may be discerned from a video feed based on minute fluctuations in skin coloration with each heartbeat). Vital readings or biometrics may be tracked using any suitable technique.
In some embodiments, the vital readings of a first user may be broadcast to one or more other users. This may add a level of excitement or strategy to the game. For example, one player may be able to discern or infer when another player is tense, and may factor that knowledge into a decision as to whether to press an attack or not. In various embodiments, the central controller 110 may track ambient conditions surrounding gameplay. These may include room temperature, humidity, noise levels, lighting, local weather, or any other conditions. The central controller may track particular sounds or types of sounds, such as a dog barking in the background, a horn honking, a doorbell ringing, a phone ringing, a tea kettle sounding off, or any other type of sound. In various embodiments, ambient conditions may be correlated to a user's gameplay. For example, the central controller 110 may determine that the user tends to perform better in colder temperatures. Therefore, ambient conditions may be used to make predictions about a user's game performance, or to recommend to a user that he seek more favorable ambient conditions (e.g., by turning on the air conditioning). In various embodiments, ambient conditions may be detected using one or more sensors of a peripheral device, using a local weather service, or via any other means.
In various embodiments, the central controller 110 may track game moves, decisions, tactics, strategies, or other game occurrences. Such a occurrences may include a weapon chosen by a user, a road chosen by a user, a path chosen, a door chosen, a disguise chosen, a vehicle chosen, a defense chosen, a chess move made, a bet made, a card played, a card discarded, a battle formation used, a choice of which player will covered which other player (e.g., in a combat scenario, which player will protect the back of which other player), a choice of close combat versus distant combat, or any other game choice made by a player or team of players. In various embodiments, the central controller may track decisions made by referees, judges, audience members, or any other participants. In various embodiments, the central controller 110 may track team interactions. The central controller may track text messages, messages, voice messages, voice conversations, or other signals transmitted between team members. The central controller may track resources passed between player characters (e.g., ammunition or medical supplies transferred). The central controller may track the relative positioning of player characters. The central controller may track any other aspect of team interaction. In various embodiments, the central controller 110 may utilize an aspect of a user's gameplay to identify the user. For example, the user may have a unique pattern of moving a mouse or hitting a keyboard. In some embodiments, a user may be subsequently authenticated or identified based on the aspect of the user's gameplay.
At step 8621, the central controller 110 may react or respond to user gameplay, according to some embodiments. In various embodiments, the central controller may adjust one or more aspects of the game (e.g., difficulty level) based on user gameplay. The central controller may increase difficulty level if the user is scoring highly relative to other users, or relative to the current user's prior scores at the same game. The central controller may decrease difficulty level if the user is scoring poorly relative to other users, is dying quickly, or is otherwise performing poorly. In various embodiments, if a user is primarily or overly reliant on one resource (e.g., on one particular weapon or vehicle), or on a small group of resources, then the central controller 110 may steer the game in such a way that the one resource (or small group of resources) is no longer as useful. For example, if the user has been relying on a motorcycle as transportation, then the central controller may steer the game such that the user has to navigate a swamp area where other vehicles (e.g., a canoe) may be preferable to a motorcycle. This may incentivize the user to become acquainted with other resources and/or other aspects of the game. In various embodiments, the central controller 110 may steer a game towards circ*mstances, situations, environments, etc., with which the player may have had relatively little (or no) experience. This may encourage the player to gain experience with other aspects of the game.
In various embodiments, elements of ambient conditions may be incorporated into a game itself. For example, if the central controller 110 detects a dog barking in the background, then a dog might also appear within a game. In various embodiments, the central controller 110 may advise or tell the user of an action to take based on observations of the user's gameplay. If the central controller has detected low metabolite levels (e.g., low sugar or low protein) with the user, the central controller may advise the user to eat and/or to quit. In various embodiments, the central controller may infer user health status from game play. In various embodiments, one or more vital signs (e.g., blood pressure) may be obtained directly or indirectly from sensors. In various embodiments, the central controller may utilize user actions as an indicator of health state or status. If a user's game performance has declined, then this may be indicative of health problems (e.g., dehydration, fatigue, infection, heart attack, stroke, etc.). In various embodiments, game performance may be measured in terms of points scored, points scored per unit of time, opponents neutralized, levels achieved, objectives achieved, time lasted, skill level of opponents beaten, or in terms of any other factor.
A decline in game performance may be defined as a reduced performance during a given time interval (e.g., the last 15 minutes, today, the most recent seven days) versus game performance in a prior time interval (e.g., the 15-minute period ending 15 minutes ago; e.g., the 15-minute period ending one hour ago; e.g., the 15-minute period ending this time yesterday; e.g., the day before yesterday; the seven-day period ending seven days ago; etc.). In various embodiments, the central controller may monitor for a decline of a certain amount (e.g., at least 10%) before conclusively determining that performance has declined. In various embodiments, a player's performance may be compared to that of other players (such as to that of other players of a similar skill level, such as to that of other players with a similar amount of experience, such as to all other players). If a player's performance is significantly worse than that of other players (e.g., 20% or more worse), then the central controller 110 may infer a health problem.
In various embodiments, improvements in a player's performance may be used to infer positive changes in health status (e.g., that the user is better rested; e.g., that the user has overcome an illness; etc.). In various embodiments, the central controller 110 may combine data on vital signs with data on player performance in order to infer health status. For example, an increased body temperature coupled with a decline in performance may serve as a signal of illness in the player. In various embodiments, the central controller 110 may initiate recording and/or broadcasting of user gameplay based sensor readings from a peripheral. Such sensor readings may include readings of vital signs. The central controller may also initiate recording and/or broadcasting based on inferred vital signs. This may allow the central controller, for example, to detect a level of excitement with the user, and initiate recording when the user is excited. The central controller may thereby capture footage that is more likely to be exciting, interesting, memorable, or otherwise noteworthy. In various embodiments, the central controller 110 may initiate recording when a user's heart rate exceeds a certain level. The level may be an absolute heart rate (e.g., one hundred beats per minute) or a relative heart rate (e.g., 20% above a user's baseline heart rate). In various embodiments, the central controller may initiate recording in response to a change in skin conductivity, blood pressure, skin coloration, breath oxygen levels, or in response to any other change in a user's vital signs.
In various embodiments, the central controller 110 may stop or pause recording when a user's vital sign or vital signs have fallen below a certain threshold or have declined by predetermined relative amount. In various embodiments, the central controller 110 may start recording or broadcasting when vital signs have fallen below a certain threshold (or decreased by a certain relative amount). The central controller may stop or pause recording when vital signs have increased above a certain threshold. In various embodiments, the central controller 110 may use a combination of sensor readings (e.g., of user vital signs) and user gameplay as a determinant of when to commence or terminate recording. For example, if the user's heart rate increases by 10% and the number of clicks per minute has increased by 20%, then the central controller may commence recording. In various embodiments, the central controller may track sensor inputs or other inputs from other users or participants, such as from audience members. These inputs may be used to determine when to start or stop recording or broadcasting. For example, the central controller may detect excitement levels in an audience member, and may thereby decide to record the ensuing gameplay action, as it may have a high chance of being interesting.
At step 8624, a peripheral device may feature some aspect of the game, according to some embodiments. In various embodiments, a peripheral device may feature, convey, or otherwise indicate some aspect of the game. A peripheral may explicitly display information, such as an amount of ammunition remaining with a player, a number of damage points sustained by a player, a set of coordinates detailing a player's location in a game, the number of opponent characters within a particular radius of the player's character, or any other game information. The information may be displayed using alphanumeric characters, bar graphs, graphs, or using any other means of presentation. In various embodiments, game information may be conveyed by a peripheral indirectly. In various embodiments, the color of a component of a peripheral (e.g., of an LED) may vary based on the health of the player's game character. For instance, if the game character is at full strength, the LED may be green, while if the game character is one hit away from dying, then the LED may be red. In various embodiments, the LED may show a range of colors between red and green (e.g., each color within the range having a different mixture of red and green), to convey intermediate health statuses of the game character.
In various embodiments, a peripheral device may convey game information using a level of sound (e.g., louder sounds convey poorer health statuses of the game character), using a volume of sound, using a pitch of sound, using a tempo (e.g., which can be varied from slow to fast), using vibrations, using a level of heat, using a level of electric shock, or via any other means. In various embodiments, a peripheral device may display or otherwise convey an attribute of another player, such as an attribute of another player's gameplay or a vital sign of another player. For example, a peripheral device may display the heart rate of another player. As another example, the color of a component of a peripheral device may cycle in sync with the breathing cycle of another player (e.g., the LED varies from orange on an inhale to yellow on an exhale then back to orange on the next inhale, and so on).
At step 8627, the central controller 110 may broadcast a game feed to others, according to some embodiments. For example, the feed may be broadcast via Twitch, via another streaming platform, via television broadcast, or via any other means. In various embodiments, part or all of a feed may be broadcast to a peripheral device, such as a peripheral device of an observing user. A feed may seek to mimic or replicate the experience of the playing user with the observing user. For example, if the playing user is receiving haptic feedback in his mouse, then similar haptic feedback may be broadcast to an observing user's mouse.
At step 8630, the central controller 110 may trigger the presentation of an advertisem*nt, according to some embodiments. In various embodiments, step 8630 may include the presentation of a promotion, infomercial, white paper, coupon, or any other similar content, or any other content. The advertisem*nt may be triggered based on one or more factors, including: events in the game; detected user gameplay; sensor inputs; detected user vital signs; stored user preferences; ambient conditions; or based on any other factors. For example, upon detection of low glucose levels, an ad for a candy bar may be triggered. The advertisem*nt may be presented to the user in various ways. the advertisem*nt may appear within the gaming environment itself, such as on an in-game billboard. The advertisem*nt may appear in a separate area on a screen, such as on the screen of a user device. The advertisem*nt may appear as an overlay on top of the game graphics. The advertisem*nt may temporarily interrupt gameplay, and may, e.g., appear full screen. In various embodiments, an advertisem*nt may appear in full or in part on a peripheral device. For example, an advertisem*nt may appear on a display screen of a mouse or of a keyboard. In various embodiments, a company's colors may be displayed with lights on a peripheral device. For example, LED Lights on a mouse may shine in the red white and blue of the Pepsi logo when a Pepsi advertisem*nt is featured. In various embodiments, a peripheral device may broadcast sound, vibrations, haptic feedback, or other sensory information in association with an advertisem*nt. For example, in conjunction with an advertisem*nt for potato chips, a mouse may rumble as if to mimic the crunching of a potato chip.
At step 8633, the user makes an in-game purchase, according to some embodiments.
The user may purchase a game resource (e.g., a weapon, vehicle, treasure, etc.), an avatar, an aesthetic (e.g., a background image; e.g., a dwelling; e.g., a landscape), a game shortcut (e.g., a quick way to a higher-level or to a different screen; e.g., a quick way to bypass an obstacle), a health enhancement for a game character, a revival of a dead character, a special capability (e.g., invisibility to other players, e.g., flight), or any other item pertinent to a game. In various embodiments, the user may purchase an item external to a game, such as an item that has been advertised to the user (e.g., a pizza from a local restaurant). In various embodiments, the user may make a purchase using a financial account, such as a financial account previously registered or created with the central controller 110. In various embodiments, prior to completing a purchase, the user may be required to authenticate himself. To authenticate himself, a user may enter a password, supply a biometric, and/or supply a pattern of inputs (e.g., mouse movements, e.g., keystrokes) that serve as a unique signature of the user. In various embodiments, an amount of authentication may increase with the size of the purchase. For example, one biometric identifier may be required for a purchase under $10, but two biometric identifiers may be required for a purchase over $10.
At step 8636, User 1 and user 2 pass messages to each other's peripheral devices, according to some embodiments. In various embodiments, a message may include words, sentences, and the like, e.g., as with traditional written or verbal communication. A message may include text and/or spoken words (e.g., recorded voice, e.g., synthesized voice). In various embodiments, a message may include images, emojis, videos, or any other graphic or moving graphic. In various embodiments, a message may include sounds, sound effects (e.g., a drum roll; e.g., a well-known exclamation uttered by a cartoon character) or any other audio. In various embodiments, a message may include other sensory outputs. A message may include instructions to heat a heating element, instructions for generating haptic sensations, instructions for increasing or decreasing the resistance of a button or scroll wheel or other actuator, instructions for releasing scents or perfumes or other olfactory stimulants, or instructions for inducing any other sensation. For example, user 1 may wish to send a message to user 2 with text “you are on fire!” and with instructions to increase the temperature of a heating element in user 2's mouse. The message may generate increased impact for user 2 because the message is experienced in multiple sensory modalities (e.g., visual and tactile).
In various embodiments, a user may explicitly type or speak a message. In various embodiments, a user may employ a sequence of inputs (e.g., a shortcut sequence) to generate a message. The central controller 110 may recognize a shortcut sequence and translate the sequence using one or more tables, such as “mapping of user input to an action/message” table 2600 and “generic actions/messages” table 2500. In various embodiments, a user may receive an alert at his peripheral device that he has received a message. The user may then read or otherwise perceive the message at a later time. The alert may comprise a tone, a changing color of a component of the peripheral device, or any other suitable alert. In various embodiments, a message may include an identifier, name, etc., for an intended recipient. In various embodiments, a message may include an indication of a peripheral device and/or a type of peripheral device that is the intended conveyor of the message. In various embodiments, a message may include an indication of a combination of devices that are the intended conveyors of the message. For example, a message may include instructions for the message to be conveyed using a mouse with a display screen and any peripheral device or user device with a speaker. In various embodiments, a message may be broadcast to multiple recipients, such as to all members of a gaming team. The message may be presented to different recipients in different ways. For example the recipients might have different peripheral devices, or different models of peripheral devices. In various embodiments, a message may contain instructions for conveying the message that specify a device-dependent method of conveyance. For example, if a recipient has a mouse with LED lights, then the LED lights are to turn purple. However, if a recipient has a mouse with no LED lights, then the recipient's computer monitor is to turn purple.
At step 8639, User 1 and user 2 jointly control a game character, according to some embodiments. In various embodiments, user 1 may control one capability of the game character while user 2 controls another capability of the game character. Different capabilities of the same game character may include: moving, using a weapon, firing a weapon, aiming a weapon, using individual body parts (e.g., arms versus legs; e.g., arms for punching versus legs for kicking), looking in a particular direction, navigating, casting a spell, grabbing or procuring an item of interest (e.g., treasure, e.g., medical supplies), building (e.g., building a barricade), breaking, solving (e.g., solving an in-game puzzle), signaling, sending a message, sending a text message, sending a spoken message, receiving a message, interpreting a message, or any other capability. For example, user 1 may control the movement of a character, while user 2 may control shooting enemy characters with a weapon. For example, user 1 may control the arms of a character, while user 2 may control the legs of a character. For example, user 1 may control the movement of a character, while user 2 communicates with other characters. In various embodiments, user 1 and user 2 jointly control a vehicle (e.g., spaceship, tank, boat, submarine, robot, mech robot), animal (e.g., horse, elephant), mythical creature (e.g., dragon, zombie), monster, platoon, army, battalion, or any other game entity. For example, user 1 may control the navigation of a spaceship, while user 2 may control shooting enemy spaceships.
In operation, the central controller 110 may receive inputs from each of user 1 and user 2. The central controller may interpret each input differently, even if they are coming from similar peripheral devices. For example, inputs from user 1 may be interpreted as control signals for a character's legs, while inputs from user 2 are interpreted as control signals for a character's arms. Prior to a game (e.g., during registration), two or more users may indicate an intent to control the same character. The users may then collectively select what aspect of the character each will control. For example, each user may check a box next to some aspect of a character that they intend to control. Subsequently, the central controller may interpret control signals from the respective users as controlling only those aspects of the character for which ta respectively signed up. In various embodiments, one or more users may indicate an intent to control the same character at some other time, such as after a game has started. In various embodiments, inputs from two or more users may be combined or aggregated in some way to control the same character, and even to control the same aspect(s) of the same character. For example, the motion of a character may be determined as the sum of the control signals from the respective users. For example, if both user 1 and user 2 attempt to move the character to the right, then the character may in fact move right. However, if user 1 and user 2 attempt to move the character in opposite directions, then the character may not move at all. In various embodiments, control signals from two or more users may be combined in different ways in order to determine an action of a character. For example, the control signal of one user may take priority over the control signal of another user when there is conflict, or the control signal of one user may be weighted more heavily than the control signal of another user. In various embodiments, more than two users may jointly control a game character, vehicle, animal, or any other game entity.
At step 8642, User 1 and user 2 vote on a game decision, according to some embodiments. A game decision may include any action that can be taken in a game. A game decision may include a route to take, a weapon to use, a vehicle to use, a place to aim, a shield to use, a message to send, a signal to send, an evasive action to take, a card to play, a chess piece to move, a size of a bet, a decision to fold (e.g., in poker), an alliance to make, a risk to attempt, a bench player to use (e.g., in a sports game), an item to purchase (e.g., a map to purchase in a game) or any other game decision. In various embodiments, when a decision is to be made, the central controller may explicitly present the available choices to all relevant users (e.g., via menu). Users may then have the opportunity to make their choice, and the choice with the plurality or majority of the vote may be implemented. In various embodiments, decisions are not presented explicitly. Instead, users may signal their desired actions (e.g., using standard game inputs), and the central controller may implement the action corresponding to majority or plurality of received signals. As will be appreciated, various other methods may be used for voting on an action in a game and such methods are contemplated according to various embodiments. In various embodiments, the votes of different users may be weighted differently. For example, the vote of user 1 may count 40%, while the votes for each of users 2, 3 and 4 may count for 20%. A candidate action which wins the weighted majority or weighted plurality of the vote may then be implemented.
At step 8645, user 2 controls user 1's peripheral device, according to some embodiments. There may be various reasons for user 2 to control the peripheral device of user 1. User 2 may be demonstrating a technique, tactic, strategy, etc., for user 1. User 2 may configure the peripheral device of user 1 in a particular way, perhaps in a way that user 1 was not able to accomplish on his own. The peripheral device belonging to user 1 may have more capabilities than does the peripheral device belonging to user 2. Accordingly, user 2 may need to “borrow” the capabilities of user 1's peripheral device in order to execute a maneuver, or perform some other task (e.g., in order to instruct or control user 2's own character). User 2 may take control of the peripheral device of user 1 for any other conceivable reason. In various embodiments, to control the peripheral device of user 1, user 2 (e.g., a peripheral device of user 2, e.g., a user device of user 2) may transmit control signals over a local network, such as a network on which both user 1's peripheral and user 2's peripheral reside. In various embodiments, control signals may be sent over the internet or over some other network, and may be routed through one or more other devices or entities (e.g., through the central controller 110). In various embodiments, the peripheral device of user 1 may include a module, such as a software module, whose inputs are control signals received from user 2 (or from some other user), and whose outputs are standard component outputs that would be generated through direct use of the peripheral device of user 1. For example, a control signal received from user 2 may be translated by the software module into instructions to move a mouse pointer for some defined distance and in some defined direction.
In various embodiments, the peripheral device of user 1 may include a module, such as a software module, whose inputs are control signals received from user 2 (or from some other user), and whose outputs become inputs into the peripheral device of user 1 and/or into components of the peripheral device of user 1. For example, the output of the software module may be treated as an input signal into a mouse button, as an input signal to a sensor on the peripheral device of user 1, or as an input signal to the entire mouse. The output of the software module would thereby mimic, for example, the pressing of a mouse button on the peripheral device of user 1, or the moving of the peripheral device of user1. In various embodiments, the software module may store a table mapping inputs (e.g., control signals received from user 2), to output signals for: (a) transmission to a user device; or (b) use as inputs to components of the peripheral device of user 1. In various embodiments, the software module may translate inputs received from another user into outputs using any other algorithm or in any other fashion.
In various embodiments, a control signal received from user 2 can be used directly (e.g., can be directly transmitted to the user device of user 1; e.g., can be directly used for controlling a game character of user 1), without modification. The peripheral device of user 1 would then be simply relaying the control signal received from user 2. In various embodiments, a hardware module or any other module or processor may be used for translating received control signals into signals usable by (or on behalf of) the peripheral device of user 1. In various embodiments, user 2 must have permission before he can control the peripheral device of user 1. User 1 may explicitly put user 2 on a list of users with permissions. User 1 may grant permissions to a category of users (e.g., to a game team) to which user 2 belongs. User 1 may grant permission in real time, such as by indicating a desire to pass control of a peripheral to user 2 in the present moment. In various embodiments, permissions may be temporary, such as a lasting a fixed amount of time, lasting until a particular event (e.g., until the current screen is cleared), lasting until ta are withdrawn (e.g., by user 1), or until any other suitable situation. In various embodiments, user 1 may signal a desire to regain control of his peripheral device and/or to stop allowing user 2 to control his peripheral device. For example, user 1 may enter a particular sequence of inputs that restore control of the peripheral device to user 2.
At step 8648, a game occurrence affects the function of a peripheral device, according to some embodiments. A game occurrence may include a negative occurrence, such as being hit by a weapon, by a strike, or by some other attack. A game occurrence may include crashing, falling into a ravine, driving off a road, hitting an obstacle, tripping, being injured, sustaining damage, dying, or any other mishap. A game occurrence may include losing points, losing resources, proceeding down a wrong path, losing a character's ability or abilities, or any other occurrence. A game occurrence may include striking out in a baseball game, having an opponent score points, having a goal scored upon you (e.g., in soccer or hockey), having a touchdown scored upon you, having a team player get injured, having a team player foul out, or any other occurrence. A game occurrence may include losing a hand of poker, losing a certain amount of chips, losing material in a chess game, losing a game, losing a match, losing a skirmish, losing a battle, or any other game occurrence.
The functionality of a peripheral device may be degraded in various ways, in various embodiments. A component of the peripheral device may cease to function. For example, a button of a mouse or a key on a keyboard may cease to register input. An output component may cease to function. For example, an LED on a mouse may cease to emit light. A display screen may go dark. A speaker may stop outputting sound. In various embodiments, a component of a peripheral device may partially lose functionality. For example, a speaker may lose the ability to output sounds above a particular frequency. A display screen may lose the ability to output color but retain the ability to output black and white. As another example, a display screen may lose the ability to output graphics but may retain the ability to output text. In various embodiments, the peripheral may lose sensitivity to inputs. A button or key may require more pressure to activate. A button or key may not register some proportion or percentage of inputs. For example, a mouse button may not register every second click. Thus, in order to accomplish a single click, a player would have to press the mouse button twice. A microphone may require a higher level of incident sound in order to correctly interpret the sound (e.g., in order to correctly interpret a voice command). A camera may require more incident light in order to capture a quality image or video feed. Various embodiments contemplate that a peripheral may lose sensitivity to inputs in other ways.
In various embodiments, one or more categories of inputs may be blocked or disabled.
A mouse motion in one direction (e.g., directly to the “East”) may not register. (However, a user may compensate by moving the mouse first “Northeast” and then “Southeast”.). In various embodiments, a sensor may be blocked or disabled. Thus, for example, the teammate of a user may be unable to ascertain the user's heart rate. Voice inputs may be disabled. Arrow keys may be disabled while text keys retain their function. Any other category of inputs may be blocked or disabled, according to some embodiments. In various embodiments, a peripheral device may generate outputs that are uncomfortable, distracting, and/or painful. For example, LED lights on a mouse may shine at full brightness, or may blink very rapidly. A heating element may become uncomfortably hot. A speaker might output a screeching sound. In various embodiments, a peripheral device may be degraded temporarily, for a predetermined amount of time (e.g., for 5 minutes) after which full functionality may be restored. In various embodiments, functionality returns gradually over some period of time. For example, functionality may return in a linear fashion over a period of 5 minutes. In various embodiments, full functionality may not necessarily be restored. In various embodiments, a peripheral device may return asymptotically to full functionality. In various embodiments, functionality is permanently effected (e.g., until the end of a game). In various embodiments, functionality may be improved or restored only upon the occurrence of some other game event (e.g., a positive game event for the player; e.g., the player successfully lands a shot on his opponent; e.g., the player finds a green ruby in the game).
At step 8651, there is a pause/break in game play, according to some embodiments. In various embodiments, a player desires to stop playing, such as to temporarily stop playing. Perhaps the player needs to get a drink or take a phone call. A player may take one or more actions to indicate he is taking a break. A player may turn over his mouse, flip over his keyboard, place his camera face-down, or otherwise position a peripheral in an orientation or configuration where it would not normally be used or would not normally function. The peripheral may then detect its own orientation, and signal to the central controller 110 that the user is taking a break. In various embodiments, when a user takes a break, the central controller takes note of a lack of input from the user (e.g., from a peripheral device of the user), and infers that the user is taking a break. When a user takes a break, the central controller 110 may pause gameplay, may inform other participants that the player has taken a break, may protect the player's character from attacks, may pause a game clock, or may take any other suitable action.
At step 8654, the game concludes, according to some embodiments. The central controller 110 may thereupon tally up scores, determine performances, determine winners, determine losers, determine prizes, determine any records achieved, determine any personal records achieved, or take any other action. The central controller 110 may award a prize to a user. A prize may include recognition, free games, game resources, game skins, character skins, avatars, music downloads, access to digital content, cash, sponsor merchandise, merchandise, promotional codes, coupons, promotions, or any other prize. In various embodiments, a peripheral device of the user may assume an altered state or appearance in recognition of a user's achievement in a game. For example, LEDs on a user's mouse may turn purple, a speaker might play a triumphant melody, a mouse may vibrate, or any other change may transpire. In various embodiments, user achievements may be broadcast to others. For example, the central controller 110 may broadcast a message to a user's friends or teammates detailing the achievements of the user.
At step 8657, a game highlight reel is created, according to some embodiments. The highlight reel may include a condensed or consolidated recording of gameplay that has transpired. The highlight reel may include sequences with high action, battle sequences, sequences where a player neutralized an opponent, sequences where a player sustained damage, sequences where a player scored points, or any other sequences. A highlight reel may include recorded graphics recorded audio, recorded communications from players, or any other recorded aspect of a game. In various embodiments, the highlight reel contains sufficient information to recreate a game, but does not necessarily record a game in full pixel-by-pixel detail. The highlight reel may store game sequences in compressed format. In various embodiments, a highlight reel may include sequences where a peripheral device has recorded sensor inputs meeting certain criteria. For example, a highlight reel may include all sequences where a player's heart rate was above 120. As another example, a highlight reel may include the 1% of the game where the user's measured skin conductivity was the highest.
In various embodiments, a highlight reel may incorporate or recreate sensory feedback, such as sensory feedback to mimic what occurred in the game. For example, when a user's friend watches the highlight reel, the user's friend may have the opportunity to feel haptic feedback in his mouse just as the user felt during the actual game play. Thus, in various embodiments, a highlight reel may contain not only visual content, but also tactile content, audio content, and/or content for any other sensory modality, modality, or any combination of modalities. Further details on how haptic feedback may be generated can be found in U.S. Pat. No. 7,808,488, entitled “Method and Apparatus for Providing Tactile Sensations” to Martin, et a. issued Oct. 5, 2010, at columns 3-6, which is hereby incorporated by reference. In various embodiments, the central controller 110 may notify one or more other users about the existence of a highlight reel, e.g., by sending them the file, a link to the file, by sending an alert to their peripheral device, or in any other fashion.
At step 8660, the central controller 110 generates recommendations for improvement of the user's gameplay, according to some embodiments. In various embodiments, the central controller 110 may analyze the user's gameplay using an artificial intelligence or other computer program. The artificial intelligence may recreate game states that occurred when the user played, and decide what it would have done in such game states. If these decisions diverge from what the user actually decided, then the central controller may inform the player of the recommendations of the artificial intelligence, or otherwise note such game states. If the artificial intelligence agrees with what the user did, then the central controller may indicate approval to the user. In various embodiments, a user may have the opportunity to replay a game, or part of a game, from a point where the user did not perform optimally or did not make a good decision. This may allow the user to practice areas where his skill level might need Improvement. In various embodiments, the central controller 110 may compare a user's decisions in a game to the decisions of other players (e.g., to skillful or professional players; e.g., to all other players) made at a similar juncture, or in a similar situation, in the game. If the user's decisions diverge from those of one or more other players, then the central controller may recommend to the user that he should have made a decision more like that of one or more other players, or the central controller may at least make the user aware of what decisions were made by other players.
Storage Devices
Referring to
According to some embodiments, the first data storage device 7140a may comprise one or more various types of internal and/or external hard drives. The first data storage device 7140a may, for example, comprise a data storage medium 7146 that is read, interrogated, and/or otherwise communicatively coupled to and/or via a disk reading device 7148. In some embodiments, the first data storage device 7140a and/or the data storage medium 7146 may be configured to store information utilizing one or more magnetic, inductive, and/or optical means (e.g., magnetic, inductive, and/or optical-encoding). The data storage medium 7146, depicted as a first data storage medium 7146a for example (e.g., breakout cross-section “A”), may comprise one or more of a polymer layer 7146a-1, a magnetic data storage layer 7146a-2, a non-magnetic layer 7146a-3, a magnetic base layer 7146a-4, a contact layer 7146a-5, and/or a substrate layer 7146a-6. According to some embodiments, a magnetic read head 7148a may be coupled and/or disposed to read data from the magnetic data storage layer 7146a-2.
In some embodiments, the data storage medium 7146, depicted as a second data storage medium 7146b for example (e.g., breakout cross-section “B”), may comprise a plurality of data points 7146b-2 disposed with the second data storage medium 7146b. The data points 7146b-2 may, in some embodiments, be read and/or otherwise interfaced with via a laser-enabled read head 7148b disposed and/or coupled to direct a laser beam through the second data storage medium 7146b. In some embodiments, the second data storage device 7140b may comprise a CD, CD-ROM, DVD, Blu-Ray™ Disc, and/or other type of optically-encoded disk and/or other storage medium that is or becomes known or practicable. In some embodiments, the third data storage device 7140c may comprise a USB keyfob, dongle, and/or other type of flash memory data storage device that is or becomes known or practicable. In some embodiments, the fourth data storage device 7140d may comprise RAM of any type, quantity, and/or configuration that is or becomes practicable and/or desirable. In some embodiments, the fourth data storage device 7140d may comprise an off-chip cache such as a Level 2 (L2) cache memory device. According to some embodiments, the fifth data storage device 7140e may comprise an on-chip memory device such as a Level 1 (L1) cache memory device. The data storage devices 7140a-e may generally store program instructions, code, and/or modules that, when executed by a processing device, cause a particular machine to function in accordance with one or more embodiments described herein. The data storage devices 7140a-e depicted in
With reference to
Mouse 7200 includes cover 7211 and outer cover 7213. Sensing mechanisms of mouse 7200 act via through hole 7215 which accommodates corresponding wheels 7230a-c. Driver module 7220 can be an electric motor that includes shaft 7222 connected to gear 7270. Driver module 7220 provides driving force to the movement of gears 7270 by the shaft 7222 to drive movement of axle 7231a and the wheels 7230a and 7230b. Wheels 7230a-c are exposed from the bottom surface of cover 7211. Wheels 7230a and 7230b are mounted on axle 7231a and are exposed through hole 7215. Wheel 7230c is rotatably mounted on another axle 7231b. Axle 7231a is rotatably mounted within another end of cover 7211.
Control module 7240 transmits a command signal to an alarm to output a warning signal and is connected to driver module 7220. Sensors 7250a-c can accurately sense and maintain the position of the mouse to keep it from falling off the desktop. Sensors 7250a-c radiate continuous sensing light to the desktop or other plane and then receive reflected light from different reflective surfaces and can record transmission time of the reflected light. Circuit board 7260 is mounted within the main body. Gears 7270 engage with each other to drive wheels 7230a and 7230b. Cleaning device 7280 can clean dust on the movement path of the mouse.
Mouse Usage
In various embodiments, it may be useful to measure the utilization of a peripheral device. In various embodiments, a peripheral device utilization is measured without reference to any applications (e.g., without reference to user device applications to which the peripheral device utilization is directed, such as to excel or to a video game). In various embodiments, it may be determined when a user's effectiveness in utilizing a peripheral device has declined. In various embodiments, it may be determined when a user's utilization of a peripheral device has the potential to be adverse or harmful to a user (e.g., by keeping the user up late at night, e.g., by impacting the user's health, etc.). In various embodiments, a determination of the effectiveness of the user's utilization of the peripheral device, or the potential for harm to a user may be determined by monitoring or comparing utilization of a peripheral device overtime. In various embodiments, utilization of a peripheral device may be monitored for any suitable purpose.
In measuring the utilization of a peripheral device, one or more types of inputs may be measured. The types of inputs may include: presses of a button; releases of a button; clicks of a button; single clicks of a button; double clicks of a button (e.g., two clicks of the button happening in rapid succession); clicks of a right button; clicks of a left button; clicks of a central button; individual interactions with a scroll wheel; degree to which a scroll wheel is turned; direction in which a scroll wheel is turned; movements of the device itself (e.g., movements of the entire mouse); direction of movement of the device; velocity of movement of the device; acceleration of movement of the device; sub-threshold inputs (e.g., pressure placed on a button that was insufficiently strong to register as a click); clicks coupled with motions of the entire device (e.g., drags); or any other types of inputs, or any combination of inputs. In various embodiments, utilization may be measured with passive inputs, such as with inputs detected at one or more sensors but not consciously made by a user. Utilization may measure such inputs as: pressure sensed on a peripheral device (e.g., resting hand pressure); heat sensed at a device (e.g., the heat of a user's hand); a metabolite level of a user; a skin conductivity of a user; a brainwave of a user; an image of a user; an image of part of a user (e.g., of the user's hands; e.g., of the user's face), or any other inputs, or any combination of inputs.
In various embodiments, combinations of inputs may provide a useful measure of utilization. With respect to a mouse, a user who is effectively using the mouse may direct a mouse pointer from a first location to a second location using a motion that is substantially a straight line. In contrast, for example, a user who is not effectively using the mouse may move the mouse pointer in the wrong direction (e.g., in a direction that is 10 degrees off from the direction of the second location with respect to the first location), or may overshoot the second location. Because the user is not being economical with his mouse motions, changes in direction of the mouse motion may be more prevalent with the user. In various embodiments, a metric of utilization may be based on some statistic of inputs measured over some period of time and/or per unit of time. A metric may include the number of inputs measured over some period of time. For example, the number of button clicks measured during a one minute interval. In various embodiments, a metric may include the aggregate of inputs measured over some period of time. For example, the total distance moved by a mouse in one minute, or the total number of degrees that a scroll wheel has turned in 1 minute. In various embodiments, a metric may include the proportion of one type of input to another type of input. For example, a metric may measure what proportion of button clicks on a mouse were left button clicks versus right button clicks.
In various embodiments, a metric may measure the proportion of time during which a user's hand was in contact with a peripheral. In various embodiments, a metric measures the proportion of sub-threshold clicks to actual clicks. If this metric increases over time, it may suggest, for example, that the user is tiring out and not concentrating on pressing a button hard enough. In various embodiments, a metric measures: (a) the aggregate absolute changes in direction of a mouse's movement divided by (b) the total absolute distance moved by the mouse, all within some unit of time (e.g., one minute). To use a simple example, suppose in one minute a mouse moves 3 inches to a user's right, then 0.5 inches to the user's left, then 2 inches directly away from a user. The mouse has changed directions twice, first by 180 degrees, then by 90 degrees, for an aggregate change in direction of 270 degrees. The mouse has moved a total absolute distance of 5.5 inches (i.e., the absolute value of the distance of each motion is added up). The metric will then take the value of 270 degrees/5.5 inches, or approximately 49 degrees per inch. In various embodiments, this metric may be computed at different time intervals. If the size of the metric is increasing from one time interval to the next, it may be indicative that the user is becoming tired and less efficient with his mouth movements.
In some cases, there may be other explanations for a changing metric. For example, a particular encounter in a video game may require a rapid series of short mouse movements in different directions. However, in various embodiments, by computing a metric over a relatively long time interval (e.g., over 10 minutes), or by computing the metric over many different intervals (e.g., over 20 1-minute intervals), the significance of other explanatory factors can be reduced, smoothed out, or otherwise accounted for. For example, where a metric is computed over many time intervals, values that represent significant outliers can be discarded as probably occurring as a result of other explanatory factors (e.g., not due to the user's fatigue).
Adjustable Mouse Parameters
In various embodiments, in response to utilization metrics (e.g., to values of a utilization metric; e.g., to changes in the value of a utilization metric over time), one or more parameters of a peripheral may be adjusted. Parameters that may be adjusted include: a sensitivity to clicks, a sensitivity to button presses, a color of a light (e.g., an LED), a brightness of a light, a background color of a display screen, a sensitivity of a touch screen, an image shown on a display screen, a rate at which a light blinks, a volume of audio output, a mapping of detected motion to reported motion (e.g., a mouse may detect 2 inches of mouse displacement but report only 1 inch of displacement; e.g., a mouse may detect a user hand speed of 6 feet per second, but report a speed of only two feet per second; e.g., a mouse may detect a 30 degree turn of a scroll wheel, but report only a 10 degree turn of the wheel, etc.), or any other parameter.
In various embodiments, a parameter may include whether or not a mouse registers an input at all (e.g., whether or not the mouse will register a right click at all). In various embodiments, a parameter may include whether or not a mouse registers any inputs at all. For example, a parameter may, upon assuming a given value, stop the mouse from functioning entirely.
Glass
Various embodiments contemplate the use of glass for such purposes as: coating substrates; display screens; touch screens; sensors; protective covers; glare reducers; fingerprint readers, or fingerprint reducers (such as so-called oleophobic screens and/or coatings); or for any other purpose. In various embodiments the Gorilla® Glass® line of glass products developed by Corning Inc. may be suitable for one or more purposes. The Gorilla® Glass® line includes such products as Gorilla® Glass™ 3, Gorilla® Glass™ 5, Gorilla® Glass™ 6, and others. Gorilla® Glass™ may provide such advantages as scratch resistance, impact damage resistance, resistance to damage even after drops from high places, resistance to damage after multiple impacts, resistance to damage from sharp objects, retained strength after impacts, high surface quality, optical purity and high light transmission, thinness, and/or lightness. Glass may be used as a flat or 2D panel, or in curved or 3D shapes to embed displays and other functionality in various surfaces and devices. Some exemplary types of glass are described in U.S. Pat. RE47,837, entitled “Crack and scratch resistant glass and enclosures made therefrom” to Barefoot, et a., issued Feb. 4, 2020, the entirety of which is incorporated by reference herein for all purposes. One glass formulation described by the patent includes: “an alkali aluminosilicate glass having the composition: 66.4 mol % SiO.sub.2; 10.3 mol % AI.sub.20.sub.3; 0.60 mol % B.sub.20.sub.3; 4.0 mol % Na.sub.20; 2.10 mol % K.sub.20; 5.76 mol % MgO; 0.58 mol % CaO; 0.01 mol % ZrO.sub.2; 0.21 mol % SnO.sub.2; and 0.007 mol % Fe.sub.20.sub.3”. However, it will be appreciated that various embodiments contemplate that other suitable glass formulations could likewise be used. Other glass products that may be used include DragontraiI™ from Asahi™ and Xensation™ from Schott™
It will be appreciated that various embodiments contemplate the use of other materials besides glass. Such materials may include, for example, plastics, thermoplastics, engineered thermoplastics, thermoset materials, ceramics, polymers, fused silica, sapphire crystal, corundum, quartz, metals, liquid metal, various coatings, or any other suitable material.
Diffusing Fiber Optics
Various embodiments contemplate the use of diffusing fiber optics. These may include optical glass fibers where a light source, such as a laser, LED light, or other source is applied at one end and emitted continuously along the length of the fiber. As a consequence the entire fiber may appear to light up. Optical fibers may be bent and otherwise formed into two or three dimensional configurations. Furthermore, light sources of different or time varying colors may be applied to the end of the optical fiber. As a result, optical fibers present an opportunity to display information such as a current state (e.g., green when someone is available and red when unavailable), or provide diverse and/or visually entertaining lighting configurations.
Diffusing fiber optics are described in U.S. Pat. No. 8,805,141, entitled “Optical fiber illumination systems and methods” to Fewkes, et a., issued Aug. 12, 2014, the entirety of which is incorporated by reference herein for all purposes.
Terms
As used herein, a “meeting” may refer to a gathering of two or more people to achieve a function or purpose.
A “company” may be a for profit or not for profit company. It could also be a small group of people who have a shared purpose, such as a club. The company could have full or part time employees located at one or more physical locations and/or virtual workers.
A “meeting owner” may refer to a person (or persons) responsible for managing the meeting. It could be the speaker, a facilitator, or even a person not present at the meeting (physically or virtually) who is responsible for elements of the meeting. There could also be multiple meeting owners for a given meeting.
A “meeting participant” may refer to an individual or team who attends one or more meetings. In some embodiments, a meeting participant could be a software agent that acts on behalf of the person. In various embodiments, the terms “meeting participant” and “meeting attendee” may be used interchangeably.
An “Admin/Coordinator” may refer to an individual or individuals who play a role in setting up or coordinating a meeting, but may not participate in the meeting itself.
A “baton” may refer to a task, obligation, or other item that may be fulfilled in portions or parts (e.g., in sequential parts). The task may be assigned to a person or a team. Upon fulfilling their portion of the task, the person or team may hand the task over to another person or team, thereby “passing the baton”. Such a task may be handed from one person to another—across meetings, across time, and/or across an organization. The task may ultimately reach completion following contributions from multiple people or teams. In various embodiments, a baton is first created in a meeting (e.g., as a task that results from a decision or direction arrived at in a meeting).
An “intelligent chair” may refer to a chair capable of performing logical operations (e.g., via a built-in processor or electronics), capable of sensing inputs (e.g., gestures of its occupants; e.g., voice commands of its occupants; e.g., pulse or other biometrics of its occupants), capable of sensing its own location, capable of outputting information (e.g., providing messages to its occupant), capable of adjusting its own configuration (e.g., height; e.g., rigidness; e.g., temperature of the backrest), capable of communicating (e.g., with a central controller), and/or capable of any other action or functionality.
As used herein, an “SME” may refer to a subject matter expert, i.e., a person with expertise or specialized knowledge in a particular area, such as finance, marketing, operations, legal, technology, a particular subdomain, such as the European market, server technology, intellectual property, or in any other area.
As used herein, a “Meeting Participant Device” or the like may refer to a device that allows meeting participants to send and receive messages before, during, and after meetings. A Meeting Participant Device may also allow meeting participants to take surveys about meetings, provide feedback for meetings and/or to engage in any other activity related to meetings. A meeting participant device may include: Smartphones (such as an Apple™ Phone™ 1 Pro or Android™ device such as Google® ™ Pixel 4™ and OnePlus™ 7 Pro); IP enabled desk phone; Laptops (MacBook Pro™ MacBook Air™, HP™ Spectre x360™, Google® ™ Pixelbook Go™, Dell™ XPS 13™); Desktop computers (Apple™ iMac 5K™, Microsoft™ Surface Studio 2™, Dell™ Inspiron 5680™); Tablets (Apple™ iPad™ Pro 12.9, Samsung™ Galaxy™ Tab S6, iPad™ Air, Microsoft® ™ Surface Pro™); Watches (Samsung™ Galaxy™ Watch, Apple™ Watch 5, Fossil™ Sport™, TicWatch™ E2, Fitbit™ Versa 2™); Eyeglasses (Iristick.Z1 Premium™, Vuzix Blade™, Everysight Raptor™ Solos™ Amazon®™ Echo™ Frames); Wearables (watch, headphones, microphone); Digital assistant devices (such as Amazon®™ Alexa™ enabled devices, Google® ™ Assistant™, Apple™ Siri™); and/or any other suitable device.
In various embodiments, a Meeting Participant Device may include a peripheral device, such as a device stored in table 1000. In various embodiments, a Meeting Participant Device may include a user device, such as a device stored in table 900.
As used herein, a “Meeting Owner Device” or the like may refer to a device that helps or facilitates a meeting owner in managing meetings. It could include the same or similar technology as described with respect to the Meeting Participant Device above.
Central Controllers
In various embodiments, central controller 110 may be one or more servers located at the headquarters of a company, a set of distributed servers at multiple locations throughout the company, or processing/storage capability located in a cloud environment—either on premise or with a third party vendor such as Amazon®™ Web Services™, Google® ™ Cloud Platform™, or Microsoft® ™ Azure™
The central controller 110 may be a central point of processing, taking input from one or more of the devices herein, such as a room controller or participant device. The central controller may have processing and storage capability along with the appropriate management software as described herein. Output from the central controller could go to room controllers, room video screens, participant devices, executive dashboards, etc.
In various embodiments, the central controller may include software, programs, modules, or the like, including: an operating system; communications software, such as software to manage phone calls, video calls, and texting with meeting owners and meeting participants; an artificial intelligence (AI) module; and/or any other software.
In various embodiments, central controller 110 may communicate with one or more devices, peripherals, controllers (e.g., house controller 8305 (
In various embodiments, the central controller 110 may communicate with: room controllers; display screens; meeting owner devices/participant devices, which can include processing capability, screens, communication capability, etc.; headsets; keyboards; mice (Key Connection Battery Free Wireless Optical Mouse & a USB 2’ Wired Pad, Logitech®; Wireless Marathon™ Mouse M705 with 3-Year Battery Life); presentation controllers; chairs; executive dashboards; audio systems; microphones; lighting systems; security systems (door locks, etc.); environmental controls (HVAC, blinds, window opacity); Bluetooth® location beacons or other indoor location systems, or any other entity.
In various embodiments, the central controller 110 may communicate with data sources containing data related to: human resources; presentations; weather; equipment status; calendars; traffic congestion; road conditions; road closures; or to any other area.
In various embodiments, the central controller may communicate with another entity directly, via one or more intermediaries, via a network, and/or or in any other suitable fashion. For example, the central controller may communicate with an item of AV equipment in a given room using a room controller for the room as an intermediary.
Embodiments
Referring to
Employees table 5000 may store information about one or more employees at a company, organization, or other entity. In various embodiments, table 5000 may store information about employees, contractors, consultants, part-time workers, customers, vendors, and/or about any people of interest. In various embodiments, employees table 5000 may store similar, analogous, supplementary, and/or complementary information to that of users table 700. In various embodiments, employees table 5000 and users table 700 may be used interchangeably and/or one table may be used in place of the other.
Employee identifier field 5002 may store an identifier (e.g., a unique identifier) for an employee. Name field 5004 may store an employee name. Start date field 5006 may store a start date, such as an employee's first day of work. Employee level field 5008 may store an employee's level within the company, which may correspond to an employee's rank, title, seniority, responsibility level, or any other suitable measure.
Supervisor field 5010 may indicate the ID number of an employee's supervisor, manager, boss, project manager, advisor, mentor, or other overseeing authority. As will be appreciated, an employee may have more than one supervisor.
Office/cube location field 5012 may indicate the location of an employee's place of work. This may be, for example, the place that an employee spends the majority or the plurality of her time. This may be the place where an employee goes when not interacting with others. This may be the place where an employee has a desk, computer, file cabinet, or other furniture or electronics or the like. In various embodiments, an employee may work remotely, and the location 5012 may correspond to an employee's home address, virtual address, online handle, etc. In various embodiments, multiple locations may be listed for an employee, such as if an employee has multiple offices. In various embodiments, a location may indicate a room number, a cube number, a floor in a building, an address, and or any other pertinent item of information.
In various embodiments, knowledge of an employee's location may assist the central controller 110 with planning meetings that are reachable by an employee within a reasonable amount of time. It may also assist the central controller 110 with summoning employees to nearby meetings if their opinion or expertise is needed. Of course, knowledge of an employee's location may be useful in other situations as well.
Subject matter expertise field 5014 may store information about an employee's expertise. For example, an employee may have expertise with a particular area of technology, with a particular legal matter, with legal regulations, with a particular product, with a particular methodology or process, with customer preferences, with a particular market (e.g., with the market conditions of a particular country), with financial methods, with financials for a given project, or in any other area. In various embodiments, multiple areas of expertise may be listed for a given employee. In various embodiments, subject matter expertise field 5014 may assist the central controller 110 with ensuring that a meeting has an attendee with a particular area of expertise. For example, a meeting about launching a product in a particular country may benefit from the presence of someone with expertise about market conditions in that country. As will be appreciated, subject matter expertise field 5014 could be used for other situations as well.
Personality field 5016 may store information about an employee's personality. In various embodiments, information is stored about an employee's personality as exhibited within meetings. In various embodiments, information is stored about an employee's personality as exhibited in other venues or situations. In various embodiments, it may be desirable to form meetings with employees of certain personalities and/or to balance or optimize personalities within a meeting. For example, if one employee tends to be very gregarious, it may be desirable to balance the employee's personality with another employee who is focused and who could be there to keep a meeting on track. In various embodiments, it may be desirable to avoid forming meetings with two or more clashing personality types within them. For example, it may be desirable to avoid forming a meeting with two (or with too many) employees that have a confrontational personality. As will be appreciated, personality field 5016 may be used for other situations as well.
Security level field 5018 may store information about an employee's security level. This may represent, for example, an employee's ability to access sensitive information. An employee's security level may be represented numerically, qualitatively (e.g., “high” or “low”), with titles, with clearance levels, or in any other suitable fashion. In various embodiments, security level field 5018 may assist the central controller 110 in constructing meetings with attendees that have permission to view potentially sensitive information that may arise during such meetings.
Security credentials field 5020 may store information about credentials that an employee may present in order to authenticate themselves (e.g., to verify their identities). For example, field 5020 may store an employee's password. An employee may be required to present this password in order to prove their identity and/or to access secure information. Field 5020 may store other types of information such as biometric information, voiceprint data, fingerprint data, retinal scan data, or any other biometric information, or any other information that may be used to verify an employee's identity and/or access levels.
Temperature preferences field 5021 may store an employee's temperature preferences, such as an employee's preferred room temperature. This preference may be useful in calculating heating energy (or cooling energy), and/or any associated emissions that may be required to maintain a room at an employee's preferred room temperature. Employee temperature preferences may influence the temperature at which an employee's office is kept, the temperature at which a meeting room hosting the employee is kept, or any other applicable temperature.
Preferences
In various embodiments, meeting owners and meeting participants could register their preferences with the central controller relating to the management and execution of meetings. Example preferences of meeting participants may include:
-
- I only want to attend meetings with fewer than 10 people.
- I do not want to attend any alignment meetings.
- I prefer morning to afternoon meetings.
- I do not want to attend a meeting if a particular person will be attending (or not attending).
- I don't like to attend meetings outside of my building or floor.
- I don't attend meetings that require travel which generates carbon output.
- Gestures that invoke action can be set as a preference. Tap my watch three times to put me on mute.
- Nodding during a meeting can indicate that I agree with a statement.
- Food preference for meetings. I only eat vegetarian meals.
- My personal mental and physical well-being at a given time.
Example preferences of meeting owners may include:
-
- I don't want to run any meetings in room 805.
- I prefer a “U” shaped layout of desks in the room.
- I prefer to have a five minute break each hour.
- I prefer the lights to be dimmed 50% while I am presenting.
- I never want food to be ordered from a particular vendor.
- I want a maximum of 25 attendees at my Monday meetings.
- I need to be able to specify camera focus by meeting type. For example, in a meeting at which a decision is being made I want the camera to be on the key decision makers for at least 80% of the time.
- My personal mental and physical well-being at a given time.
Example preferences or conditions of the central controller may include:
-
- There are certain days on which meetings cannot be scheduled.
- For a given room, certain levels of management have preferential access to those rooms.
Preferences field 5022 may store an employee's preferences, such as an employee's preferences with respect to meetings. Such preferences may detail an employee's preferred meeting location or locations, preferred amenities at a meeting location (e.g., whiteboards), preferred characteristics of a meeting location (e.g., location has north-facing windows; e.g., the location has circular conference tables), room layouts (e.g., U-shaped desk arrangements), etc. Preferences field 5022 may include an employee's preferred meeting times, preferred meeting dates, preferred meeting types (e.g., innovation meetings), preferred meeting sizes (e.g., fewer than ten people), or any other preferences.
Preferred standard device configurations field 5024 may store information about how an employee would like a device configured. The device may be a device that is used in a meeting. The device may include, for example, a smartphone, a laptop, a tablet, a projector, a presentation remote, a coffee maker, or any other device. Exemplary preferences may include a preferred method of showing meeting attendees (e.g., show only the speaker on a screen; e.g., show all attendees on screen at once), a preferred method of broadcasting the words spoken in a meeting (e.g., via audio; e.g., via a transcript), a preferred method of alerting the employee when his input is required (e.g., via flashing screen; e.g., via a tone), a preferred method of alerting the employee when the meeting is starting, a preferred method of alerting the employee when a particular topic arises, a preferred method of showing the results of an in-meeting survey (e.g., via a bar graph; e.g., via numerical indicators for each available choice), or any other preferences.
Email field 5026 may store an employee's email address. In various embodiments, a company email address may be stored for an employee. In various embodiments, a personal email address may be stored for an employee. In various embodiments, any other email address or addresses may be stored for an employee.
Phone field 5028 may store an employee's phone number. In various embodiments, a company phone number may be stored for an employee. In various embodiments, a personal phone number may be stored for an employee. In various embodiments, any other phone number or numbers may be stored for an employee.
In various embodiments, any other contact information for an employee may be stored.
Such contact information may include a Slack™ handle, a Twitter® handle, a LinkedIn® handle, a Facebook® username, a handle on a social media site, a handle within a messaging app, a postal address, or any other contact information.
In various embodiments, storing an employee's contact information may allow the central controller 110 to send a meeting invite to an employee, to send reminders to an employee of an impending meeting, to check in on an employee who has not appeared for a meeting, to remind employees to submit meeting registration information (e.g., a purpose or agenda), to send rewards to employees (e.g., to send an electronic gift card to an employee), or to communicate with an employee for any other purpose.
Referring to
Further details on how meetings may occur via conferencing can be found in U.S. Pat. No. 6,330,022, entitled “DIGITAL PROCESSING APPARATUS AND METHOD TO SUPPORT VIDEO CONFERENCING IN VARIABLE CONTEXTS” to Doree Seligmann, issued Dec. 11, 2011, at columns 3-6, which is hereby incorporated by reference.
A meeting may serve as an opportunity for people to share information, work through problems, provide status updates, provide feedback to one another, share expertise, collaborate on building or developing something, or may serve any other purpose.
In various embodiments, a meeting may refer to a single-event or session, such as a gathering that occurs from 2:00 PM to 3:00 PM on Apr. 5, 2025. In various embodiments, a meeting may refer to a series of events or sessions, such as to a series of ten sessions that occur weekly on Monday at 10:00 AM. The series of sessions may be related (e.g., they may all pertain to the same project, may involve the same people, may all have the same or related topics, etc.). As such, in various embodiments, the series of sessions may be referred to collectively as a meeting. Meetings may also include educational sessions like a Monday 2 PM weekly Physics class offered by a university for a semester.
Meeting identifier field 5102 may store an identifier (e.g., a unique identifier) for a meeting.
Meeting name field 5104 may store a name for a meeting. A meeting name may be descriptive of the subject of a meeting, the attendees in the meeting (e.g., a meeting called ‘IT Roundtable’ may comprise members of the IT department), or any other aspect of the meeting, or may have nothing to do with the meeting, in various embodiments.
Meeting owner field 5106 may store an indication of a meeting owner (e.g., an employee ID; e.g., an employee name). A meeting owner may be an individual or a group of individuals who run a meeting, create a meeting, organize a meeting, manage a meeting, schedule a meeting, send out invites for a meeting, and/or who play any other role in the meeting, or who have any other relationship to the meeting.
Meeting type field 5108 may store an indication of a meeting type. Exemplary meeting types include learning; innovation; commitment; and alignment meetings. A meeting type may serve as a means of classifying or categorizing meetings. In various embodiments, central controller 110 may analyze characteristics of a meeting of a certain type and determine whether such characteristics are normal for meetings of that type. For example, the central controller may determine that a scheduled innovation meeting has more people invited then would be recommended for innovation meetings in general.
In various embodiments, central controller 110 may analyze the relative frequency of different types of meetings throughout a company. The central controller may recommend more or fewer of certain types of meetings if the number of a given type of meeting is out of proportion to what may be considered healthy for a company. In various embodiments, meeting types may be used for various other purposes.
Level field 5110 may store a level of a meeting. The level may represent the level of the intended attendees for the meeting. For example, the meeting may be an executive-level meeting if it is intended to be a high-level briefing just for executives. In various embodiments, prospective attendees with ranks or titles that do not match the level of the meeting (e.g., a prospective attendee's rank is too low) may be excluded from attending the meeting. In various embodiments, meetings of a first-level may take priority over meetings of a second level (e.g., of a lower level). Thus, for example, meetings of the first level may be granted access to a conference room before meetings of a second level when meeting times overlap. In various embodiments, meeting levels may be used for other purposes as well.
Location field 5112 may store a location of a meeting. The location may include a building designation, a campus designation, an office location, or any other location information. In various embodiments, if a meeting is to be held virtually, then no information may be stored in this field.
Room identifier field 5114 may store an identifier of a room in which a meeting is scheduled to occur. The room may be a physical room, such as a conference room or auditorium. The room may be a virtual room, such as a video chat room, chat room, message board, Zoom® call meeting, WebEx® call meeting, or the like. In some embodiments, a meeting owner or central controller 110 may switch the room location of a meeting, with the record stored in the room identifier field updated to reflect the new room.
Start date field 5116 may store the start date of a meeting. In various embodiments, the start date may simply represent the date of a solitary meeting. In various embodiments, the start date may represent the first in a series of sessions (e.g., where a meeting is recurring).
Time field 5118 may store a time of a meeting, such as a start time. If the meeting comprises multiple sessions, the start time may represent the start time of each session. In embodiments with offices in different time zones, time field may be expressed in GMT.
Duration field 5119 may store a duration of a meeting, such as a duration specified in minutes, or in any other suitable units or fashion. The duration may represent the duration of a single session (e.g., of a recurring meeting).
Frequency field 5120 may store a frequency of a meeting. The field may indicate, for example, that a meeting occurs daily, weekly, monthly, bi-weekly, annually, every other Thursday, or according to any other pattern.
End date field 5122 may store the end date of a meeting. For meetings with multiple sessions, this may represent the date of the last session. In various embodiments, this may be the same as the start date.
Phone number field 5124 may store a phone number that is used to gain access to a meeting (e.g., to the audio of a meeting; e.g., to the video of a meeting; e.g., to slides of a meeting; e.g., to any other aspect of a meeting). In various embodiments, phone number field 5124 or a similar type field may store a phone number, URL link, weblink, conference identifier, login ID, or any other information that may be pertinent to access a meeting.
Tags field 5126 may store one or more tags associated with a meeting. The tags may be indicative of meeting purpose, meeting content, or any other aspect of the meeting. Tags may allow for prospective attendees to find meetings of interest. Tags may allow for comparison of meetings (e.g., of meetings with similar tags), such as to ascertain relative performance of similar meetings. Tags may serve other purposes in various embodiments.
Project number or cost center association’ field 5128 may store an indication of a project and/or cost center with which a meeting is associated. Field 5128 may thereby allow tracking of the overall number of meetings that occur related to a particular project. Field 5128 may allow tallying of costs associated with meetings related to a particular cost center. Field 5128 may allow for various other tracking and/or statistics for related meetings. As will be appreciated, meetings may be associated with other aspects of an organization, such as with a department, team, initiative, goal, or the like.
Ratings field 5130 may store an indication of a meeting's rating. A rating may be expressed in any suitable scale, such as a numerical rating, a qualitative rating, a quantitative rating, a descriptive rating, a rating on a color scale, etc. A rating may represent one or more aspects of a meeting, such as the importance of the meeting, the effectiveness of the meeting, the clarity of the meeting, the efficiency of the meeting, the engagement of a meeting, the purpose of the meeting, the amount of fun to be had in the meeting, or any other aspect of the meeting. A rating may represent an aggregate of ratings or feedback provided by multiple attendees. A rating may represent a rating of a single session, a rating of a group of sessions (e.g., an average rating of a group of sessions), a rating of a most recent session, or any other part of a meeting.
In various embodiments, ratings may be used for various purposes. A rating may allow prospective attendees to decide which meetings to attend. A rating may allow an organization to work to improve meetings (e.g., the way meetings are run). A rating may aid an organization in deciding whether to keep a meeting, cancel a meeting, change the frequency of a meeting, change the attendees of a meeting, or change any other aspect of a meeting. A rating may allow an organization to identify meeting facilitators who run good meetings. A rating may be used for any other purpose, in various embodiments.
Priority field 5132 may store a priority of a meeting. A priority may be represented using any suitable scale, as will be appreciated. The priority of a meeting may serve various purposes, and various embodiments. A company employee who is invited to two conflicting meetings may attend the meeting with higher priority. If two meetings wish to use the same room at the same time, the meeting with higher priority may be granted access to the room. A meeting priority may help determine whether a meeting should be cancelled in certain situations (e.g., if there is inclement weather). Employees may be given less leeway in declining invites to meetings with high priority versus those meetings with low priority. As will be appreciated, the priority of a meeting may be used for various other purposes.
Related meetings field 5134 may store an indication of one or more related meetings.
Related meetings may include meetings that relate to the same projects, meetings that are on the same topic, meetings that generate assets used by the present meeting (e.g., meetings that generate ideas to be evaluated in the present meeting; e.g., meetings that generate knowledge used in the present meeting), meetings that have one or more attendees in common, meetings that use assets generated in the present meeting, meetings run by the same meeting owner, meetings that occur in the same location, meetings that occur at the same time, meetings that occur at an approximate time, or meetings with any other relationship to the present meeting. Any given meeting may have no related meetings, one related meeting, or more than one related meeting, in various embodiments.
In various embodiments, table 5100, or some other table, may store an indication of meeting connection types. This may include an indication of types of devices that may be used to participate in a meeting (e.g., mobile, audio only, video, wearable). This may include an indication of types of connections that may be used to participate in the meeting (e.g., Wi-Fi®, WAN, 3rd party provider).
Referring to
Meeting identifier field 5202 may store an indication of the meeting in question. Date field 5203 may store an indication of the date of the meeting or of a particular session of the meeting. In some cases, an attendee might attend one session of a meeting (e.g., of a recurring meeting) and not attend another session of the meeting.
Attendee identifier field 5204 may store an indication of one particular attendee of a corresponding meeting. As will be appreciated, table 5200 may include multiple records related to the same meeting. Each record may correspond to a different attendee of the meeting.
Role field 5206 may store a role of the attendee at the meeting. Exemplary roles may include meeting owner, facilitator, leader, note keeper, subject matter expert, or any other role or function. In various embodiments, a role may be ‘interested participant’ or the like, which may refer to a non-meeting participant, such as a CEO, CIO, VP/Director of Meetings, or Project Sponsor. In various embodiments, a role may be ‘central controller administrator, ‘central controller report administrator’, or the like, which may refer to a participant that performs or oversees one or more functions of the central controller as it pertains to the meeting. In various embodiments, a role may be ‘meeting room and equipment administrator’ or the like, which may refer to a participant that oversees operations of the meeting room, such as ensuring that projectors and AV equipment are running properly.
An attendee with no particular role may simply be listed as attendee, or may be designated in any other suitable fashion.
Manner field 5208 may store an indication of the manner in which the attendee participated in the meeting. For example, an attendee may participate in person, via video conference, via web conference, via phone, or via any other manner of participation.
Referring to
Meeting identifier field 5302 may store an indication of the meeting for which engagement is tracked. Date field 5304 may store the date of the meeting or of a session of the meeting. This may also be the date for which engagement was recorded.
Time field 5306 may store an indication of the time when the engagement was recorded, measured, noted, observed, reported, and/or any other pertinent time. For example, engagement may be observed over a five minute interval, and time field 5306 may store the time when the interval finishes (or the time when the interval starts, in some embodiments). In various embodiments, time field 5306 may store the entire interval over which the engagement was recorded. In various embodiments, an attendee's engagement may be measured multiple times during the same meeting or session, such as with the use of surveys delivered at various times throughout a meeting. In such cases, it may be useful to look at changes in engagement level over time. For example, if an attendee's engagement has decreased during a meeting, then the attendee may be sent an alert to pay attention, may be provided with a cup of coffee, or may otherwise be encouraged to increase his engagement level. In one embodiment, if engagement levels are low for a particular meeting, central controller 110 may send an instruction to the company catering facilities to send a pot of coffee to the room in which the meeting is occurring.
Attendee identifier field 5308 may store an indication of the attendee for whom engagement is measured.
Engagement level field 5310 may store an indication of the attendee's level of engagement. This may be stored in any suitable fashion, such as with a numerical level, a qualitative level, quantitative level, etc. In various embodiments, an engagement level may refer to a quantity of engagement, such as a number of comments made during a discussion. In various embodiments, an engagement level may refer to a quality of behavior, such as the relevance or value of comments made during a discussion. In various embodiments, an engagement level may refer to some combination of quality and quantity of a behavior. An engagement level may refer to any suitable measure or metric of an attendee's behavior in a meeting, in various embodiments.
In various embodiments, an engagement level may be connected to a biometric reading. The biometric may correlate to a person's visible behaviors or emotional state within a meeting. In various embodiments, for example, an engagement level may be a heart rate. A low heart rate may be presumed to correlate to low engagement levels. In various embodiments, field 5310 may store a biometric reading, such as a heart rate, breathing rate, measure of skin conductivity, or any other suitable biometric reading.
Engagement indicator(s) field 5312 may store an indication of one or more indicators used to determine an engagement level. Indicators may include biometrics as described above. Exemplary indicators include signals derived from voice, such as rapid speech, tremors, cadence, volume, etc. Exemplary indicators may include posture. For example, when a person is sitting in their chair or leaning forward, they may be presumed to be engaged with the meeting. Exemplary indicators may be obtained through eye tracking. Such indicators may include eye movement, direction of gaze, eye position, pupil dilation, focus, drooping of eyelids, etc. For example, if someone's eyes are just staring out into space, it may be presumed that they are not engaged with the meeting. As will be appreciated, many other engagement indicators are possible.
Burnout risk field 5314 may store an indication of an attendee's burnout risk. Burnout may refer to a significant or lasting decline in morale, productivity, or other metric on the part of an attendee. It may be desirable to anticipate a burnout before it happens, as it may then be possible to prevent the burnout (e.g., by giving the attendee additional vacation days, by giving the attendee less work, etc.). A burnout risk may be stored in any suitable fashion, such as on a “high”, “medium”, “low” scale, on a numerical scale, or in any other fashion.
A burnout risk may be inferred via one or more indicators. Burnout indicators field 5316 may store one or more indicators used to assess or detect an attendee's burnout risk. Exemplary indicators may include use of a loud voice, which may portend a high burnout risk. Exemplary indicators may include steady engagement, which may portend a low burnout risk. Burnout risk may also be inferred based on how often an attendee declines invites to meetings (e.g., an attendee might decline 67% of meeting invites). A high rate of declining invites might indicate that the attendee is overworked or is simply no longer interested in making productive contributions, and may therefore be burning out. An exemplary indicator might be a degree to which an attendee's calendar is full. For example, an attendee with a calendar that is 95% full may represent a medium risk of burnout. In various embodiments, multiple indicators may be used in combination to form a more holistic picture of an employee's burnout risk. For example, an employee's rate of declining meeting invites may be used in conjunction with the employee's calendar utilization to determine an employee's burnout risk. Referring to
Meeting feedback table 5400 may store feedback provided about a meeting. The feedback may come from meeting attendees, meeting observers, from recipients of a meeting's assets, from contributors to a meeting, from a meeting owner, from management, from facilities management, or from any other parties to a meeting or from anyone else.
Meeting feedback may also be generated via automatic and/or computational means. For example, the central controller 110 may process an audio recording of the meeting and determine such things as the number of different people who spoke, the degree to which people were talking over one another, or any other suitable metric. In some embodiments, meeting feedback may be provided by a user via headset 4000, such as by providing a verbal message of support for another meeting attendee.
In various embodiments, meeting feedback may be stored in aggregate form, such as the average of the feedback provided by multiple individuals, or such as the aggregate of feedback provided across different sessions of a meeting. In various embodiments, feedback may be stored at a granular level, such as at the level of individuals.
Meeting feedback may be useful for making changes and or improvements to meetings, such as by allowing prospective attendees to decide which meetings to attend, or for any other purpose.
Meeting feedback can be expressed in any suitable scale, such as a numerical rating, a qualitative rating, a quantitative rating, a descriptive rating, a rating on a color scale, etc.
In various embodiments, feedback may be provided along a number of dimensions, subjects, categories, or the like. Search dimensions may cover different aspects of the meeting. In some embodiments, feedback could be provided regarding room layout, air conditioning noise levels, food and beverage quality, lighting levels, and the like.
Meeting identifier field 5402 may store an indication of the meeting for which feedback is tracked. Effectiveness of facilitation field 5404 may store an indication of effectiveness with which the meeting was facilitated. Other feedback may be stored in such fields as: ‘Meeting Energy Level’ field 5406; ‘Did the Meeting Stay on Track?’ field 5408; ‘Did the Meeting Start/End on Time?’ field 5410; ‘Room Comfort’ field 5412; ‘Presentation Quality’ field 5414;
‘Food Quality’ field 5418; ‘Room lighting’ field 5420; ‘Clarity of purpose’ field 5422; Projector quality’ field 5424; ‘Ambient noise levels’ field 5426; ‘Strength of Wi-Fi® Signal’ field 5428; ‘Room cleanliness’ field 5430; and ‘view from the room’ field 5432 where the field labels themselves may be explanatory of the type of feedback stored in such fields.
‘Overall rating’ field 5416 may store an overall rating for a meeting. The overall rating may be provided directly by a user or by multiple users. The overall rating may be computationally derived from feedback provided along other dimensions described herein (e.g., the overall rating may be an average of feedback metrics for effectiveness of facilitation, meeting energy level, etc.). The overall rating may be determined in any other suitable fashion.
Other feedback may be related to such questions as: Were meeting participants encouraged to provide their opinions?; Was candor encouraged?; Was the speaker's voice loud enough?; Was the speaker understandable?; Did the meeting owner know how to use the technology in the room?
In various embodiments, the central controller 110 may inform the meeting owner during or after the meeting that clarity is low (or may provide some other feedback to the meeting owner or to any other participant). Feedback could be private to the meeting owner, or it could be made available to everyone in the room, or just to management.
In various embodiments, feedback about the meeting owner goes to the meeting owner's boss (or to any other person with authority over the meeting owner, or to any other person).
In various embodiments, feedback about the meeting may be used as a tag for the meeting. The tag may be used in searching, for example.
In various embodiments, other feedback may relate to meeting content (presentation, agenda, meeting assets, etc.), and may address such questions as: Was the content organized efficiently?; Was the content clear and concise?; Was the content appropriate for the audience? For example, was the presentation too technical for an executive level meeting?
In various embodiments, other feedback may relate to presentation material and slide content, and may address such questions as: How long did the presenter spend on each slide?; Were the slides presented too quickly?; Were some slides skipped?; What type of slides result in short or long durations?; How long did the presenter spend on slides related to the meeting purpose or agenda?; Did the presenter finish the presentation within the allotted time?; Were there too many words on each slide?; Did the presentation include acronyms?; Was there jargon in the presentation?; Were graphs, figures, and technical materials interpretable and readable?; Which slides in meeting participants return to review? The answers to these questions could be used to tag low clarity scores to particular material, presentations, or individual slides.
In various embodiments, other feedback may relate to technology, and may address such questions as: Was all room equipment working throughout the meeting?; Did external factors (home Wi-Fi®, ISP provider, energy provider disruption) contribute to poor use of technology?; Was equipment missing from the room (for example chairs, projectors, markers, cables, flip charts, etc.)?
In various embodiments, other feedback may relate to room setup, and may address such questions as: Was the room difficult to locate?; Were participants able to locate bathrooms?; Was the room A/C or heating set appropriately for the meeting?; Was the room clean?; Were all chairs and tables available per the system configuration?; Was the screen visible to all participants?; Were the lights working?; Was the room unlocked?; Was the room occupied?; Was food/beverage delivered on-time and of high quality?
Referring to
Meeting identifier field 5502 may store an indication of the meeting in question. Date field 5504 may store an indication of the date of the meeting or of a particular session of the meeting. In some cases, an attendee might attend one session of a meeting (e.g., of a recurring meeting) and not attend another session of the meeting.
Employee identifier field 5506 may store an indication of one particular employee or attendee of a corresponding meeting. Role field 5508 may store a role of the attendee at the meeting as described above with respect to field 5206. ‘Confirmed/Declined meeting’ field 5510 may store an indication of whether the employee confirmed his or her participation in the meeting or declined to participate in the meeting. In various embodiments, field 5510 may indicate that the employee actually attended the meeting, or did not actually attend the meeting.
‘Time arrived’ field 5512 may indicate when an employee arrived at a meeting. This may represent a physical arrival time, or a time when the employee signed into a meeting being held via conferencing technology, and/or this may represent any other suitable time.
‘Time departed’ field 5514 may indicate when an employee departed from a meeting (e.g., physically departed; e.g., signed out of a virtual meeting; etc.).
‘Travel time to meeting location’ field 5516 may indicate an amount of time that was required for the employee to travel to a meeting. The travel time may be the time it actually took the employee to reach the meeting. The travel time may be a time that would generally be expected (e.g., a travel time of the average person at an average walking pace; e.g., a travel time of the average driver at an average driving speed; etc.). In various embodiments, the travel time may assume the employee started at his office or his usual location. In various embodiments, the travel time may account for the employee's actual location prior to the meeting, even if this was not his usual location. For example, the travel time may account for the fact that the employee was just attending another meeting and was coming from the location of the other meeting.
‘Travel time from meeting location’ field 5518 may indicate an amount of time that was required for the employee to travel from a meeting to his next destination. Similar considerations may come into play with field 5518 as do with field 5516. Namely, for example, travel times may represent actual or average travel times, destinations may represent actual or typical destinations, etc.
‘Employee rating by others’ field 5520 may represent a rating that was given to an employee by others (e.g., by other attendees of the meeting). The rating may reflect an employee's participation level, an employee's contribution to the meeting, an employee's value to the meeting, and/or any other suitable metric.
Referring to
Employee identifier field 5602 may store an indication of an employee. Meeting identifier field 5604 may store an indication of a meeting. If the appointment is not a meeting, there may be no identifier listed. Subject field 5606 may store a subject, summary, explanation, or other description of the appointment. For example, field 5606 may store the subject of a meeting if the appointment is for a meeting, or it may describe a ‘Doctor call’ if the appointment is for the employee to speak to his doctor.
Category field 5608 may store a category of the appointment. Exemplary categories may include ‘Meeting’ for appointments that are meetings, ‘Personal’ for appointments that are not work related (e.g., for an appointment to attend a child's soccer game), ‘Individual’ for appointments to spend time working alone, or any other category of appointment. In various embodiments, categories are input by employees (e.g., by employees who create appointments; e.g., by meeting organizers; e.g., by employees conducting a manual review of calendars). In various embodiments, a category is determined programmatically, such as by classifying the subject of an appointment into the most closely fitting category.
Date field 5610 may store the date of the appointment. Start time field 5612 may store the start time of the appointment. Duration field 5614 may store the duration of the appointment. In various embodiments, a separate or alternate field may store an end time of the appointment.
‘Company/personal’ field 5616 may store another means of classifying the appointment. In this case, the appointment may be classified as either company (e.g., work-related), or personal (not work-related).
Referring to
Project ID field 5702 may store an identifier (e.g., a unique identifier) for a project. Name field 5704 may store a name associated with a project. ‘Summary’ field 5706 may store a summary description of the project.
Exemplary projects may include a project to switch all employees' desktop computers to using the Linux™ operating system; a project to allow employees to work remotely from the office in a manner that maximizes data security; a project to launch a new app; a project to obtain up-to-date bids from suppliers of the organization. As will be appreciated, any other suitable project is contemplated.
Start date field 5708 may store a start date of the project. Priority field 5710 may store a priority of the project. Expected duration field 5712 may store an expected duration of the project.
Percent completion field 5714 may store the percentage of a project that has been completed. Various embodiments contemplate that other metrics of a project completion may be used, such as number of milestones met, percent of budget spent, quantity of resources used, or any other metric of project completion.
Budget field 5716 may store a budget of the project.
Personnel requirements field 5718 may store personnel requirements of the project. In various embodiments, personnel requirements may be expressed in terms of the number of people required and/or in terms of the percentage of a given person's time (e.g., of a given workday) which would be devoted to a project. For example, a personnel requirement of ‘10 people at 75% time’ may indicate that the project will require 10 people, and that each of the 10 people will be utilizing 75% of their time on the project. In various embodiments, personnel requirements may be specified in additional terms. For example, personnel requirements may indicate the departments from which personnel may be drawn, the number of personnel with a given expertise that will be required (e.g., the number of personnel with java expertise), the number of personnel with a given title that will be required (e.g., the number of project managers), or any other requirements for personnel.
Referring to
Project ID field 5802 may store an identifier of a project. Employee ID field 5804 may store an indication of an employee who is somehow involved or associated with the project. Role field 5806 may store an indication of an employee's role within a project. Exemplary roles may include: project manager; lead developer; communications strategist; procurement specialist; or any other role, or any other function, or any other association to a project.
Referring to
Project ID field 5902 may store an identifier of a project. Milestone ID field 5904 may store an identifier (e.g., a unique identifier) of a milestone.
Sequence number field 5906 may store a sequence number representing where the present milestone falls in relation to other milestones within the project. For example, the first milestone to be accomplished in a project may receive a sequence number of 1, the second milestone to be accomplished in a project may receive a sequence number of 2, and so on. As will be appreciated, sequence numbers may be designated in any other suitable fashion, such as with roman numerals, with letters of the alphabet, by counting up, by counting down, or in any other manner. In various embodiments, field 5906 (or another field) may also store an indication of the total number of milestones in a project, or of the highest sequence number in the projects. For example, a sequence number may be stored as “3 of 8”, indicating that the milestone is the third milestone out of eight milestones in the project. In various embodiments, it may be intended that some milestones be completed in parallel. Exemplary milestones to be completed in parallel may be designated “3A”, “3B”, etc., or may use any other suitable designation.
Summary field 5908 may store a summary or other description of the milestone.
Exemplary summaries include: draft request for proposal; implement pilot with legal group; stress test; review all vendor proposals; or any other summary or description.
Due date field 5910 may store a date when the milestone is due for completion. Percent complete field 5912 may store an indication of what percentage (or fraction) of a milestone has been completed.
Approver(s) field 5914 may store an indication of one or more people who have the authority or ability to approve that a milestone has been completed. For example, an approver might be a project manager, a vice president of a division overseeing a project, a person with expertise in the technology used to accomplish the milestone, or any other suitable approver. Violations field 5916 may store an indication of one or more violations that have occurred on a project.
Referring to
In various embodiments, an asset may include information for improving company operations, or meetings themselves. In various embodiments, an asset may include a map, an office map, a campus map, or the like. An exemplary map 6300 is depicted in
Table 6000 may store information about assets. Table 6000 may be useful for a number of reasons, such as allowing an employee to search for an educational deck, allowing an employee to find a summary of a meeting that he missed, allowing employees to act in accordance with decisions that have been made, allowing employees to review what had been written on a whiteboard, etc.
In various embodiments, table 6000 may be used in addition to, instead of, and/or in combination with asset library table 1900.
Asset ID field 6002 may store an identifier (e.g., a unique identifier) of an asset. Asset type field 6004 may store an indication of an asset type. Exemplary asset types may be: a presentation deck; notes; meeting minutes; decisions made; meeting summary; action items; photo of whiteboard, or any other asset type. Exemplary asset types may include drawings, renderings, illustrations, mock-ups, etc. For example, an asset might include a draft of a new company logo, a brand image, a mock-up of a user interface for a new product, plans for a new office layout, etc. Exemplary asset types may include videos, such as training videos, promotional videos, etc.
In various embodiments, an asset may include a presentation or presentation template formatted for a particular meeting type or audience (e.g., formatted for executives, members of the board of directors, a project sponsor, a team meeting, a one-on-one, etc.).
In various embodiments, an asset may include a progress report, progress tracker, indication of accomplishments, indication of milestones, etc. For example, an asset may include a Scrum Board, Kanban Board, etc.
In various embodiments, assets may be divided or classified into other types or categories. In various embodiments, an asset may have multiple classifications, types, categories, etc.
Meeting ID field 6006 may store an identifier of a meeting with which an asset is associated. For example, if the asset is a deck, the meeting may be the meeting where the deck was used. If the asset is a decision, the meeting may be the meeting where the decision was made.
Creation date field 6008 may store a date when an asset was created. In various embodiments, one or more dates when the asset was modified (e.g., the date of the most recent modification) may also be stored.
Author field 6010 may store the author or authors of an asset. In various embodiments, authors may include contributors to an asset. For example, if an asset is a photo of a whiteboard, then the authors may include everyone who was at the meeting where the whiteboard was populated.
Version field 6012 may store the version of an asset. In various embodiments, an asset may undergo one or more updates, revisions, or other modifications. Thus, for example, the version number may represent the version or iteration of the asset following some number of modifications. At times, it may be useful for an employee to search through older versions of an asset, perhaps to see what the original thinking behind an idea was before it got removed or changed.
Tags field 6014 may store one or more tags associated with an asset. Tags may provide explanatory information about the asset, indicate an author of an asset, indicate the reliability of the asset, indicate the finality of the asset, indicate the state of the asset, indicate the manner in which the asset was generated, indicate feedback about an asset, or provide any other information pertinent to an asset. Exemplary tags include: rated 8/10; author eid204920; computer transcription; needs VP confirmation; short-term items; all items approved by legal; medium quality.
Keywords field 6016 may store one or more keywords or other words, numbers, phrases, or symbols associated with an asset. Keywords may be excerpted from an asset. For example, keywords may be taken from the title of the asset. Keywords may be words that describe the subject or the nature of the asset but are not necessarily literally in the asset. Keywords may be any other suitable words. In various embodiments, keywords may serve as a means by which an employee can locate an asset of interest. For example, if an employee wants to learn more about a certain topic, then the employee may search for assets where the keywords describe the topic. Exemplary sets of keywords include: mission statement, vision, market impact, value prop, customer segments, breakeven, technology roadmap, fiber cables, cloud, personnel, resources, European market, SWOT analysis.
Rating field 6018 may store one or more ratings for the asset. Ratings may represent the utility of the asset, the quality of the asset, the importance of the asset, and/or any other aspect of the asset, and/or any combination of aspects of the asset.
Asset data field 6020 may represent the data comprising the asset itself. For example, if the asset is a deck, then data field 6020 may store the actual PowerPoint file data for the deck. If the asset is a photograph, then data field 6020 may store an actual JPEG file of the photograph. In various embodiments, table 6000 may store a link or reference to an asset, rather than the asset data itself (e.g., the asset may be stored in a separate location and table 6000 may store a link or reference to such location).
Presentation Materials
Many company presentations include a deck such as a Microsoft® PowerPoint™ presentation that is emailed to participants and projected for meeting participants to view and discuss during a meeting. Presentation materials can also include videos, white papers, technical documents, instruction manuals, checklists, etc. These presentation materials, however, are often stored on local computers that are not searchable by other individuals.
Various embodiments bring the content of all presentation materials into the central controller 110 (or stored in a cloud provider in a way that is accessible by the central controller) so that they are available to any meeting owner, participant, or employee of the company. A central store of all presentations could include access to historical presentations.
Referring to
Table 6100 may store information about presentations. Table 6100 may be useful for a number of reasons, such as allowing an employee to search for a particular presentation, a presentation on a topic of interest, the latest in a series of presentations, highly rated presentations, etc. Table 6100 may also allow, for example, comparison of different attributes of a presentation (e.g., number of slides; e.g., number of tables; etc.), in order to ascertain what attributes of a presentation improve the presentation's effectiveness. Table 6100 may also allow a user to search through presentation decks on a particular topic so that he or she can use material from those decks to aid in the creation of a new presentation deck. Table 6100 may be used for various other purposes as well.
In various embodiments, table 6100 may be used in addition to, instead of, and/or in combination with meeting assets table 6000. In various embodiments, a presentation is a type of asset.
Asset ID field 6102 may store an identifier of an asset, where, in this case, the asset is a presentation. Number of slides field 6104 may store the number of slides. Number of words field 6106 may store the number of words in the presentation. In various embodiments, a density of words per slide may be computed from fields 6104 and 6106 (e.g., by dividing the number of words described in 6106 by the number of slides described in 6104).
Size of the file field 6108 may store the size of a file that represents the presentation (e.g., the size of a PowerPoint file comprising the presentation). Presentation software version field 6110 may store the software, software version, application, program, or the like used for a presentation (e.g., Microsoft® PowerPoint™ for Mac® version 16.35; Keynote™ 11.0; Google® slides).
Number of graphics field 6112 may store the number of graphics used in the presentation. Graphics may include pictures, charts, graphs, tables, maps, animations, illustrations, word clouds, or any other graphic, or any other information.
Number and type of tags field 6114 may store an indication of the number and/or types of tags associated with a presentation. Tags may include descriptive tags, which may describe the nature, subject matter or content of the presentation (e.g., to aid in searching for the presentation), or a portion thereof. Tags may include ratings tags, which may evaluate the presentation, or a portion thereof, along one or more dimensions (e.g., quality, clarity, relevance, reliability, currency, etc.). In various embodiments, a tag may apply to the presentation as a whole. In various embodiments, a tag may apply to a portion of the presentation, such as to an individual slide, an individual graphic, a group of slides, a group of graphics, a section of the presentation, or to any other portion of the presentation. With tags, an employee may be able to search for the “financials” portion of a presentation on the “Mainframe architecture” project, for example.
Number of times presented field 6116 may store an indication of the number of times the presentation has been presented (e.g., the number of meetings in which the deck has been featured).
Template used field 6118 may store an indication of a template that was used in creating the presentation. In various embodiments, it may be desirable that presentations on certain topics or for certain purposes follow a specific format. This format may be dictated by a template. For example, a project evaluation committee may wish that all proposals for new projects follow a set format that is dictated by a “Project proposal” template. As another example, it may be desirable that all presentations that are seeking to educate the audience follow a particular format that has been found conducive to learning. Such presentations may follow a “Learning template”. The presence of templates may also assist the creator of a presentation in creating the presentation more rapidly.
In various embodiments, there may be multiple templates available for creating a certain type of presentation. For example, there may be multiple types of business plan templates. Those specific template children may depend on the nature of the business plan, the preferences of the presentation creator, or on any other factor. Example templates depicted for field 6118 include: learning template #3; business plan template #8; financials template #3.
Time to create presentation field 6120 may store an indication of the time it took to create the presentation. In various embodiments, this may be an indicator of the quality of a presentation. In various embodiments, a company may wish to make it easier or more efficient to create presentations, and therefore may wish to track how long it took to make every presentation and watch for decreases in creation time over time.
Key points field 6122 may store key points that are in the presentation. These may represent key insights, takeaways, summaries, topics, decisions made, or any other key points, or any other points. Field 6122 may allow employees to search for presentations covering points of interest to them.
Take away summary included field 6124 may indicate whether or not the presentation includes a take away summary. In various embodiments, it may be desirable to encourage presenters to include a take away summary, so the presence of such a summary may be tracked. In various embodiments, an employee with limited time may wish to search for presentations with takeaway summaries and read such summaries rather than reading the entire presentation. A takeaway summary may be used in other embodiments as well.
Security level field 6126 may indicate a security level of the presentation. The level may be expressed in terms of a minimum title or rank an employee must have in order to access the presentation. Example security levels include: general; manager+; VP+. Security levels may be expressed in other terms or scales as well. For example, security levels may be specified in terms such as “general”, “sensitive”, “secret”, “top secret”, or using any other scale or terminology.
In various embodiments, portions of a presentation may have their own security levels. For example, the first slide in a presentation may be available for general consumption at the company, whereas another slide may have a higher security level and be accessible only to managers and above. In various embodiments, security levels may apply to individual slides, groups of slides, sections of a presentation, individual graphics, groups of graphics, and/or any other portion or subset of a presentation.
Presentation creation date field 6130 may store the date the presentation was created. In various embodiments, this or another field may store the date of the last revision of the presentation.
Presentation rating field 6132 may store an indication of a rating given to the presentation. A rating may be expressed in any suitable scale (e.g., quantitative, qualitative, etc.). A rating may represent one or more aspects of a presentation, such as the importance of the presentation, the effectiveness of the presentation, the clarity of the presentation, or any other aspect of the presentation. A rating may represent an aggregate of ratings or feedback provided by multiple people. A rating may represent any other suitable statistic.
Acronyms field 6134 may store an indication of acronyms used in the presentation. The field may include an explanation or expansion of the acronym(s). In various embodiments, this may provide a convenient means for uninitiated readers to see what the acronyms mean. In various embodiments, acronyms may be tracked by a company with the desire to reduce the use of acronyms within presentations. Example acronyms include: DCE—data communications equipment; IMAP-internet message access protocol, FCE—frame check sequence.
Tags field 6136 may store one or more tags associated with a presentation. Tags may provide explanatory information about the presentation, indicate an author of the presentation, indicate the reliability of the presentation, indicate the finality of the presentation, indicate the state of the presentation, indicate the manner in which the presentation was generated, indicate feedback about an presentation, or provide any other information pertinent to an presentation. Exemplary tags include: pr75660791, pr71427249 (i.e., this presentation is associated with project IDs pr75660791 and pr71427249), DCE, learning; business plan, market assessment; Projections, financials, pr96358600.
Referring to
Table 6200 may store information about components of presentations, such as a particular page of a PowerPoint™ presentation or a chart from a pdf document. Presentation components could also include portions of a video or audio file. Table 6200 may be useful for a number of reasons, such as allowing meeting participants to rate particular components of a presentation, such as by providing a numeric rating for each of three important slides from a presentation as opposed to an overall rating for the presentation. Table 6200 may also allow a user to identify the highest rated sales chart from a large library of presentations, and to use that sales chart at a sales team Town hall presentation. Table 6200 may be used for various other purposes as well.
In various embodiments, table 6200 may be used in addition to, instead of, and/or in combination with meeting presentation table 6100. In various embodiments, a presentation component is a type of asset.
Asset ID field 6202 may store an identifier of an asset, where, in one embodiment, the asset is a presentation. Component ID field 6204 identifies a component of an asset, such as a single slide page from a presentation. In this example, the presentation is the asset and the component is the slide page. Each identified asset may contain many components identified by component ID 6204.
Component type field 6206 may store an indication of the component being identified. For example, a component type might be PowerPoint™ slide 7, a graphic file from a Keynote™ presentation, a section of a presentation that discusses benefits of a new software package for the finance department, a two-minute audio clip from a 30-minute CEO all hands presentation, etc.
Average rating field 6208 may store one or more ratings for the component ID. Ratings may represent the utility of the component, the quality of the component, the importance of the component, and/or any other aspect of the component, and/or any combination of aspects of the component. Ratings could be aggregated numerical ratings one a scale of one to ten, such as ratings of 7.5 or 8.2. Ratings could be provided by meeting attendees who attended one or more meetings in which the component was presented, providing a rating after review of the component via a user device in communication with central controller 110.
Ratings associated with presentation components could be useful in identifying employees who produce high quality assets. For example, a component with a high rating can be traced through component ID field 6204 to the corresponding meeting asset ID field 6202 and then, through presentation assets table 6000, to author field 6010 to determine the identity of the author or the presentation from which the component was a part.
With reference to
Map 6300 depicts two houses 6302 and 6304 with an outdoor area 6306. In one example, houses 6302 and 6304 may be located next to each other, with outdoor area 6306 being located between the two houses. As depicted in map 6300, houses 6302 and 6304 each have only one floor. However in various embodiments, houses with multiple floors may be depicted. In some embodiments, devices within the map 6300 are under the control of a central controller 110 which may use wired or wireless connections to send commands or requests to various devices and locations in one or more of the houses. This allows game players, computer users, and virtual call participants to employ peripherals (e.g., game consoles, headsets, mice, keyboards) or user devices (e.g., smartphone, smart watch) to communicate with central controller 110 in order to command various devices throughout one or more locations. It will be understood that this layout of houses is for illustrative purposes only, and that any other shape or layout of houses could employ the same technologies and techniques.
The depicted map view includes various devices and represents one exemplary arrangement of rooms, walls, furniture, and devices. However, various embodiments contemplate that any suitable arrangement of rooms, walls, furniture, and devices, and any suitable quantity of devices (e.g., quantity of chairs; e.g., quantity of cameras) may likewise be used.
House 6302 has main entrance 6310a and backyard entrance 6310b. House 6304 has entrance 6310c. The outdoor area 6306 may comprise a front yard, backyard, porch, balcony, swimming pool, etc. In various embodiments, the outdoor area 6306 may be fenced-off.
Inside houses 6302 and 6304 are depicted various rooms, including living rooms, dining rooms, kitchens, offices, bedrooms, bathrooms, game rooms, etc. Various embodiments contemplate that houses may include other types of rooms even if not explicitly depicted (e.g., exercise areas, roof areas, balconies, basem*nts, atrium space, storage space, etc.).
House 6302 includes hallway 6346a, and house 6304 includes hallway 6346b. Map 6300 depicts various cameras, such as camera 6352b which observes the outdoor area 6306, and camera 6352a which observes hallway area 6346a. Inside houses 6302 and 6304 are depicted various windows. It will be appreciated that map 6300 depicts an arrangement of rooms according to some embodiments, but that various embodiments apply to any applicable arrangement of rooms.
House controller 6305 may be configured to manage devices throughout houses 6302 and 6304, communicating with those devices via wired or wireless signals. In some embodiments, house controller 6305 may also send a signal to one or more room lights 6363 to go dark or lower their intensity in order to make other lights or displays more visible. Additionally, house controller 6305 may send a signal to shade controller 6369 instructing it to lower the shade for one or more windows in a house as a way to make a game experience more immersive.
Identification readers 6308a and 6308b are positioned at the entry points 6310a and 6310c, respectively, and serve to identify people and allow/deny access as they attempt to move through the entry points. For example, identification readers can be RFID readers to scan a badge, a camera to identify the person via face recognition, a scanner to identify a person by a carried user device, a microphone for voice recognition, or other identification technology. Identification readers 6308a and 6308b may communicate with headsets worn by users in order to receive identifying information. In some embodiments, a user authenticates himself using his headset in communication with an identification reader. In some embodiments, identification readers 6308a-b transmit data about people entering or leaving house 6302 and 6304 and transmit data to house controller 6305 or directly to central controller 110, e.g., for the purposes of communicating with game players in a house within a house or with other houses in order to enhance game play.
Access controls 6311a, 6311b, and 6311c can lock or unlock a door leading into houses 6302 and 6304. Such controls could be used, for example, to enable a game player to remotely allow access to a house to join one or more other players in a game. In some embodiments, a user authenticates himself at an access control point using biometrics transmitted from his headset (e.g., spoken passwords, voiceprint, fingerprint, iris scan).
Various rooms and locations throughout houses 6302 and 6304 could include Living Rooms 6315, Dining Rooms 6317, Kitchens 6319, Bedrooms 6321, Bathrooms 6323, Game Areas 6325, Desks 6327, Chairs 6329, Walls 6331, Smart Boards 6333, Tables 6335, Refrigerators 6337, etc.
Living rooms 6315a and 6315b can serve as spaces for families to gather, and for game activities that require more than one player. Dining rooms 6317a and 6317b may primarily be a place for meals, though it can also serve as another place to play games as well. Kitchens 6319a and 6319b can hold food and beverage products as well as devices for game play. For example, kitchens 6319a-b could include a refrigerator, oven, stove, sink, coffee maker, hot water dispenser, microwave oven, hot plate, toaster, and the like. Devices within kitchens 631a-b could be controlled by house controllers 6305a-b. In some embodiments, a coffee maker could be instructed to turn on ten minutes before the first game of each day, so that coffee is ready when game participants walk into living room 6315a. Bedrooms 6321a, 6321b, 6321c, 6321d, 6321e, and 6321f can also host game sessions. In some embodiments, a number of players may play a shared or collaborative game in which they each occupy separate bedrooms but communicate and play a game through house controller 6305a-b or via central controller 110. Bathrooms 6323a, 6323b, 6323c, and 6323d may have communication devices such as speakers 6355 or room lights 6363 that can provide messages to players such as a warning that game play is going to resume in five minutes. Game area 6325 is adjacent to living room 6315a, and in some embodiments serves as a dedicated game play area.
Houses 6302 and 6304 are also shown including objects that can support or enhance activities with a house (e.g., game play, video conference calls). Desks 6327a, 6327b, 6327c, 6327d, and 6327e can hold user devices and peripheral devices. For example, desk 6327c might have a computer, keyboard, headset, and mouse on its surface. Chairs 6329a, 6329b, 6329c, 6329d, 6329e, 6329f, 6329g, 6329h, 6329i, 6329j, 6329k, 63291, and 6329m can also be used for many purposes, including game play or virtual calls. Chairs 6329a-m can provide seating for a game participant. In some embodiments, chairs 6329a-m could include input and output sensors, powered wheels, tilt sensors, display screens, speakers, location detection technology (e.g., GPS), and the like. In some embodiments, house controller 6305 can send and receive messages from chairs 6329a-m. For example, the location detection technology of chair 6329g could send a signal to house controller 6305a every hour, allowing for inventory control of chair 6329g which would allow central controller 110 to know when chairs had been moved within a house. In other embodiments, chairs 6329a-m include built-in buttons for game inputs, voting, messaging, volume control, temperature control, etc. Walls 6331a, 6331b, 6331c, 6331d, 6331e, 6331f, and 6331g can be used as a surface on which projectors 6367a-g may project images, video, messages, etc.
Smart board 6333 can capture ideas, drawings, lists, and other information, and in some embodiments transmit them to house controller 6305a for storage or processing, or transmit the data directly to central controller 110 for storage or processing. In some embodiments, information from smart board 6333 may be used to update data tables in house controller 6305a or central controller 110 such as user game preferences, messaging between game players, game character strategies, etc.
Tables 6335a and 6335b can provide a surface on which game players can place devices (e.g., laptop computers, smartphones) as well as peripherals (e.g., mouse, keyboard, game controller, headset). In one embodiment, speakers 6355 and microphones 6357 (which could be combined into a speakerphone) may be built into one or more tables 6335a-b. In some embodiments, tables 6335a-b include built-in touch sensitive displays (not shown) which allow game participants to enter information and view data being presented on the table surface. In some embodiments, tables 6335a and 6335b can communicate with peripheral devices such as a headset, mouse, keyboard, etc.
Refrigerators 6337a and 6337b can hold food and beverages for consumption by gaming participants. In one embodiment, refrigerator 6337a has a locking mechanism which is controlled via communications with house controller 6305a or central controller 110. In this embodiment, a game player could reward another game player via a user device by sending an instruction to house controller 6305a to send a signal to refrigerator 6337a to unlock so that the rewarded game participant could take out a snack item. In some embodiments, refrigerators 6337a-b are configured as a vending machine in which instructions can be sent from house controllers 6305a-b to vend one or more products for gaming participants.
Motion sensors 6350a, 6350b, 6350c, 6350d, 6350e, 6350f, and 6350g may be positioned throughout map 6300. In some embodiments, motion sensors 6350a-g capture movements of occupants throughout map 6300 and transmit the data to central controller 110 for storage or processing, e.g., for the purposes of locating users, identifying users, assessing engagement and energy level in a meeting, etc. In some embodiments, motion sensors 6350a-g may transmit data directly to central controller 110. In various embodiments, motion sensors 6350a-g capture data about people entering or leaving map 6300 and transmit data to house controllers 6305a-b or directly to central controller 110 (e.g., for the purposes of knowing where other users are). In some embodiments, motion sensors 6350a-g can be set for a low resolution mode in which only coarse movement may be detected. For example, only movements of large objects may be detectable, such as the movement of one or more people, while movements of smaller objects such as dogs or cats are not detected. In various embodiments, the resolution of motion sensors 6350a-g may vary by location in the house, by time of day, day or the week, or altered based on events such as the detection of a fire in which case the motion sensors 6350a-g may immediately switch to high resolution mode. In various embodiments, the resolution of motion sensors 6350a-g may be stored in a database at house controller 6305 or central controller 110. In some embodiments, peripheral devices such as a headset with built-in or attached motion sensors may communicate directly with central controller 110 or house controller 6305 in order to provide motion detection data from wherever the headset wearing user is located.
Cameras 6352a, 6352b, 6352c, 6352d, and 6352e may be configured to record video or still images of locations throughout map 6300. In some embodiments, Cameras 6352a-e capture a video signal that is transmitted to house controllers 6305a-b via a wired or wireless connection for storage or processing. In some embodiments, house controllers 6305a-b may then transmit the video to central controller 110. In other embodiments, any of cameras 6352a-e send a video feed directly to central controller 110. In one embodiment, a game player might bring up the video feed from one or more of cameras 6352a-e in order to keep track of the location of other game players. Such a video feed, for example, could allow a first player in bedroom 6321b to see a feed from camera 6352e to identify that a second game player had gone back to house 6304 and would thus not be likely to return to the game in the next two minutes. In some embodiments, cameras 6352a-e can be set by users for low resolution mode in which fewer pixels of detail are captured. For example, the resolution of a single image or frame of video captured might range from a high or ten million pixels to a low of 100 pixels. Low resolution modes may be useful when a user needs more privacy or anonymity, but still wants to convey basic information to other users. For example, a user might select a resolution mode of 1,000 pixels per image in order to convey that a group of people are playing video games in living room area 6315a, but at that resolution it may not be possible to identify any of the people in the image. In some embodiments, peripheral devices such as a headset with one or more cameras may communicate directly with central controller 110 or house controller 6305 in order to provide camera images or video from wherever the headset wearing user is located.
Windows 6354a, 6354b, 6354c, 6354d, 6354e, and 6354f can include dynamic tinting technology. In some embodiments, examples include electrochromic glass, photochromic glass, thermochromic glass, suspended-particle, micro-blind, and polymer-dispersed liquid-crystal devices. Windows 6354a-f can have an associated direction. For example, window 6354b may be facing west while window 6354c may be facing east. Knowing the direction in which windows are facing can be helpful in those embodiments in which sun angle may be used to determine optimum times during the day for viewing of screens during a game, or for knowing during which time frame sunlight might be expected to be in the eyes of game players in a particular room.
Speakers 6355a, 6355b, 6355c, 6355d, 6355e, 6355f, 6355g, 6355h, and 6355i can broadcast sounds and audio related to games, messages, background music, etc. In various embodiments, a first game player could hear comments during a game from a second user at another location. In one embodiment, game audio follows a user as she walks through house 6302. For example, she might start a game in bedroom 6321b, and then walk toward kitchen 6319a, passing motion sensor 6350b which then tracks her movement and sends a command to speaker 6355b to relay the current game audio via that speaker. She may then move into living room 6315a where again she is tracked by motion sensor 6350b, which results in game audio being transmitted to speaker 6355a and stopped in speaker 6355b. In this way, the player is able to move about the house while continuing to keep up with audio (such as audio messages from teammates) while being away from her computer in bedroom 6321b. In other embodiments, video from a user's game may be displayed on screens or projected on walls as the user moves through a house as tracked by motion sensors. In some embodiments, peripheral devices such as a headset with speakers may communicate directly with central controller 110 or house controller 6305 in order to receive audio signals that may be played back to the user via the user's headset speakers as the user walks throughout a house.
Microphones 6357a, 6357b, 6357c, 6357d, 6357e, 6357f, 6357g, and 6357h allow for audio throughout houses 6302 and 6304 to be picked up and transmitted to house controllers 6305a-b or central controller 110. In various embodiments, users may issue verbal commands that are received via microphones 6357a-h. In some embodiments, microphones 6357a-h may have a range of available sensitivities, allowing a user to select a sensitivity level that might be lower in order to capture some louder sounds, but not pick up quieter sounds like conversations that a user would like to keep private. Such sensitivity settings may be stored with house controller 6305 or central controller 110. In some embodiments, peripheral devices such as a headset with one or more microphones may communicate directly with central controller 110 or house controller 6305 in order to provide verbal commands.
Displays 6360a and 6360b are devices that can provide a video/audio signal. In some embodiments, this is a computer monitor or a large flat screen television that can display a game. In other embodiments, displays 6360a-b indicate messages for a first user from a second user, game highlight reels, and the like.
Room lights 6363a, 6363b, 6363c, 6363d, and 6363e are devices that provide light to rooms in houses 6302 and 6304. Room lights 6363a-e could include lamps, ceiling lights, outdoor lights, ring lights, etc. In some embodiments, suitable lighting technology could include LED, fluorescent, or incandescent. In various embodiments, lights 6363a-e can provide a continuum of lighting power under the control of house controller 6305 or from a user device.
Color lighting devices 6365a, 6365b, 6365c, 6365d, 6365e, 6365f are capable of generating light of many colors that could illuminate all or part of a room. For example, a game player could decide that a game had reached a tension moment and that red lighting in living room 6315a would enhance the experience of the game session. The game player then sends a color change request with a user device (such as a smartphone) that transmits the request to house controller 6305a which then sends a signal to color lighting device 6365a and 6365b which then begin to output red light for living room 6315a. In some embodiments, peripheral devices such as a headset with color lighting capability may communicate directly with central controller 110 or house controller 6305 in order to provide lighting changes via a user's headset that may be seen by the user as well as other users who are nearby.
Projectors 6367a, 6367b, 6367c, 6367d, 6367e, 6367f, and 6367g can display information (e.g., video, photos, game screens, virtual call participants, messaging) on a wall, ceiling, floor, table, window shade, outside wall, or other surface on which light can be projected. In some embodiments, projectors 6367a-g can provide messages to game players, such as words of encouragement from another team member. In other embodiments, projectors 6367a-g can provide supplemental game data (e.g., number of lives left, distance to a goal, number of points earned) which can act as a second screen of information in addition to a main screen display 6360 on which a game is being played. In some embodiments a user can control one of projectors 6367a-g to generate a spotlight 6375 in order to highlight a user; for example, a user could direct house controller 6305a to cause projector 6367a to generate spotlight 6367 illuminating seat 6329c during a game play session with another player announcing (in the style of introducing a prizefighter) saying “and now, coming in at five years experience in Castle Crusade, with three Ultimate Battle Victories, in the green shirt, Gary!” In some embodiments, generating a spotlight 6375 can be synced with actions of speakers 6355a and 6355c, display 6360, color lighting device 6365a and 6365b, and smell generator 6371 for added effect. Projectors 6387a-g can project images on walls 6331a-f or display 6360 for presentations, movies, still images, or entertainment. In some embodiments, peripheral devices such as a headset with projector may communicate directly with central controller 110 or house controller 6305 in order to receive projection video which can be projected from the headset's projector.
Shade controllers 6369a, 6369b, 6369c, 6369d, 6369e, and 6369f can be used to drive motors which can raise or lower shades in front of windows. In one embodiment, a game player can reduce the amount of natural light in the room by sending a request, via a user device (e.g., a smartphone) to a house controller 6305 which then relays the command to shade controller 6369 to lower the shade to reduce the amount of sunlight getting into a room.
Smell generator 6371 can generate a variety of different smells that can change the mood of the room using digital sense technology in which scents are pushed out into the room. In some embodiments, scent generation technology employs storage modules containing scents which are then disbursed based on signals from a user. An example commercially available smell generator is the SmXT1™ from SensoryCo® of Thousand Palms, California. Research has shown that smells have an effect on people. For example, certain smells are known to calm people (e.g., rosemary, lavender, jasmine, vanilla, lemon, cinnamon). In one embodiment, a game player may decide that team members are too agitated, and send a request to house controller 6305 to generate one or more smells known to calm people, with house controller 6305 then sending a request on to smell generator 6371 to release the desired smells.
Air conditioning units 6373a, 6373b, 6373c, and 6373d can adjust the temperature of the room, heating or cooling as necessary. In some embodiments, air conditioning units 6373a-d can also manage the humidity level of the room. House controllers 6305a-b could send signals to air conditioning units 6373a-d based upon requests received from central controller 110. In other embodiments, game players can use a user device to communicate a request for a temperature change to either house controller 6305 or directly to air conditioning unit 6373.
Weather sensors 6375a and 6375b can detect environmental data such as temperature, humidity, rainfall intensity, cloud cover, wind speed, wind direction, barometric pressure, visibility, and the like. This data may be transmitted to house controller 6305 or to central controller 110 so that it can be made available to user devices and peripheral devices. For example, weather sensor 6375a may detect heavy rainfall at house 6302 and send this information to house controller 6305a and central controller 110, where it can be provided on a display screen of a mouse to another user who is in another state or country.
In some embodiments, map 6300 may be stored with central controller 110, and could thus be sent to user devices as a way to help users know where game play is taking place. For example, a game player in living room 6315a may be finishing a game that ends at 3:00 PM, and wants to know how long it will take to get to their next game which begins at 3:00 PM in living room 6315b. By downloading map 6300 from central controller 110, the user can clearly see the location of the game session and estimate how long it will take to walk to that location. With that in mind, the game participant may leave living room 6315a extra early given that it may be a long walk to living room 6315b. In one embodiment, central controller 110 draws a path on map 6300 from living room 6315a to living room 6315b to make it easier for the user to identify how to get to that room. In some embodiments, alternate routes may be shown on map 6300. For example, there may be two paths to get to a game room, but only one path passes by kitchen 6319b where a user can get some coffee on the way to the game. In some embodiments, users have preferences stored with the central controller 110, such as a preference to drink coffee between 8:00 AM and 10:00 AM. In this example, central controller 110 may create a gaming path for a user that includes a stopping point at a kitchen when a user is attending meetings in the 8:00 AM to 10:00 AM timeframe.
In various embodiments, central controller 110 may estimate how long it will take for a user to get from one game play location to another. For example, after determining a path to take, central controller 110 may calculate the distance and then multiply this distance by the user's walking speed to estimate how long of a walk it is from one location to another. In some embodiments, a path between two game locations may employ one or more different modes of transportation which have different estimated speeds. For example, a user might walk for part of the path and then drive during another part of the path. In some embodiments, the speed of one mode may depend on the time of day or other factors. For example, getting from a game location in one building to a game location in another building may require a drive across town. That might take 10 minutes during off-peak times, but could take 30 minutes when there is traffic or bad weather. Central controller 110 can retrieve traffic information and weather data to help create a more accurate estimate of game player travel time in such cases.
In various embodiments, individuals in the same house 6302 may want to play a game in different rooms. A parent in game area 6325 initiates a request for play through a peripheral (e.g., mouse, keyboard, headset) by using an established key combination for an individual in room 6321c. The request is sent to room controller 6305a or central controller 110 which transmits the request to the requested participant's enabled peripheral. The enabled peripheral may light up, vibrate, make a sound or display an image based on the preference the player has established for the requester. The requested player recognizes the alert and confirms or denies the request on the peripheral device by initiating the desired input (e.g., mouse click, movement, verbal command) or verbal command through one of microphones 6357a-d with the response is transmitted through room controller 6305a or central controller 110. In the same manner a request is sent to a peripheral, room 6321c with color lighting capabilities 6365c could light up in red to alert the individual that a request for play was initiated. Projector 6367b in room 6321c could also show a game avatar or player name on the wall of the requestor to alert the individual that play is requested.
In various embodiments, individuals in different homes 6302 and 6304 may want to play a game. A first user in house 6302 and room 6321c initiates a request for a game play session with a second user through a peripheral (e.g., mouse, keyboard, headset) by using an established key combination. The request is sent to room controller 6305a or central controller 110 which then transmits the request to the second user (who is currently in room 6321f) via room controller 6305b or central controller 110 to the peripheral device. The second user's mouse may light up, vibrate, make a sound, or display an image based on the preference the second user has established for the first user. The second user recognizes the alert and confirms or denies the request on the peripheral device by initiating the desired input (e.g., mouse click, movement, verbal input). The response is transmitted through room controller 6305b and/or central controller 110 to the first user's home controller 6305a or central controller 110. In the same manner a request is sent to a peripheral device, room 6321c, with color lighting capabilities 6365c which could light up in red to alert the second user that a request for play was initiated. Projector 6367b in room 6321c could also project on the walls the game avatar or player name of the second user to alert the individual that play from another person was requested. Likewise, either player in house 6302 or 6304 may confirm or deny the request by providing a verbal command (e.g., ok, wait 5 minutes) to the first user using microphones 6357a-h and the response delivered via speakers 6355a-i.
In some embodiments, headset 4000 from house 6300 may help a parent incentivize a child to take out the trash to earn game points, food or allowance as a way to reward their completion of a chore. In one embodiment, a parent in kitchen 6319b may alert a child in room 6321f that it is time to take out the trash. The parent may initiate the communication through a headset 4000 by using an established command saved in data storage 4057 and selecting button 4030a-b or verbal request for the child through microphone 4014 (e.g., ‘take out the trash’). The request is sent to house controller 6305b or central controller 110 which transmits the request to the child's headset 4000. The headset may light up, vibrate, make a sound or display a message based on the preference that the child has established for requests received from the headsets. The child may collect the garbage from house 6300 and take it to the garbage can. This activity is recorded on the child's headset 4000 through forward facing camera 4022a-b. When completed, the child may transmit the video to the parent's headset 4000 for viewing on display 4046. When confirmed, the parent may recognize completion of the task by selecting a pre-established reward saved in data storage 4055 with button 4030a-b. The reward may be in the form of increased game time, game tokens, pizza or allowance money to the child. The child's headset may display the reward on display 4046 from preferred rewards stored in the data storage 4057 for use. The response communication between headsets may be sent to home controller 6305b or central controller 110 and transmitted to the parent's and child's headset for alerts. The requests and responses could also be provided to speaker 6355b in kitchen 6319a or displayed on walls in rooms 6319b and 6321f from projectors 6367g or 6367e.
In some embodiments, as chores are completed, sounds may be emitted from headset 4000 or other devices from house 6300 as a way to create excitement. A child is given a checklist of chores by the parent (e.g., clean room, fold laundry, feed the dog) and may be loaded on the child's headset 4000 through network port 4060. As the child performs the chore, camera 4022a-b may recognize the activity through processor 4055 and begin to play lively and fun music for the child through speaker 4010a-b or outward speaker 4074 as a way to motivate them and create a more pleasant experience. As the chore is completed, the headset may communicate with home controller 6305b or central controller 110 and begin to a play chimes, bells or provide words of encouragement (e.g., ‘great job, keep it up’) in speakers 6355a-i or celebratory images (e.g., balloons, ‘great work’, emojis) displayed on house 6300 walls 6331d-f from projectors 6367a-g.
In some embodiments, headset 4000 in house 6300 may facilitate the use of a countdown timer to motivate a person to complete a task. For example, the child is given a checklist of chores by the parent (e.g., clean room, fold laundry, feed the dog) and are pre-established on the child's headset 4000 that must be completed within 30 minutes. As the child performs the chore, camera 4022a-b recognizes the activity through processor 4055 and begins to display the countdown timer on the walls using projectors 6367a-g (e.g., ‘time remaining 28:52’). As the time gets closer to completion, a clock sound may also be played in speakers 6355a-i or 4010a-b to provide increased excitement to complete the chores on time. The headset may communicate with home controller 6305b or central controller 110 to facilitate alerts, sounds and displays to headset 4000 and other peripheral devices.
In various embodiments, headset 4000 from house 6300 may facilitate the display of the lost and assignment of chores to a team (e.g., a collective group of children in a home) as a way to encourage cooperation in completing tasks. A team may be given a checklist of chores by the parent (e.g., clean the kitchen, fold laundry, feed the dog, take out the garbage) and stored on each child's headset 4000 and data storage 4057. This list may be provided on display 4046 of each child's headset or on smartboard 6333 or walls 6331d-f from projectors 6367a-g. User 1 may scroll through the list and use microphone 4014 to indicate they will clean the kitchen. Display 4046, smartboard 6333 or walls 6331d-f from projectors 6367a-g may be updated to show that the chore is no longer available for selection by the other children. User 2 indicates they will take the chores of folding laundry and feeding the dog and may select those from smartboard 6333. Display 4046, smart board 6333 or walls 6331d-f from projectors 6367a-g may be updated to show the remaining chore (e.g., take out the garbage. User 3 may select button 4030a-b and choose the final chore, take out the garbage. Display 4046, smartboard 6333 or walls 6331d-f from projectors 6367a-gmay update to indicate all chores have been selected and users assigned. The headset may communicate with home controller 6305a or central controller 110 to facilitate alerts, sounds and displays to headset 4000 and other peripheral devices.
Gamification
In some embodiments, headset 4000 in house 6300 may be used as an extension of a virtual game for collecting and using objects. A user playing a computer game in room 6325 with headset 4000 may decide to select his house 6300 as an extra space for virtual play with button 4030a-b or in the game. As the user walks through room 6315a, headset 4000 projector 4076 may display pictures of gold stars on wall 6331a that must be captured to earn points. The user may approach the wall and touch the gold stars. Camera 4022a-b may record the activity and send it to house controller 6305a and central controller 110 for communication to the virtual game for collecting points. In a similar manner, the user may wish to use items in the home as shields to defend themselves in a game. The user stores the plate image in the data storage 4055 as an item to be used in game play using camera 4022a-b. As a war game is taking place, the user may walk to the kitchen 6319a, open the cabinet and grab a dinner plate. The camera 4022a-b may notice the user holding the plate. As other players shoot at the user in the game, the plate is used as a virtual shield deflecting the weapon. Likewise, in many games, virtual players may perform tasks or collect items to gain energy. The user playing a game notices they are running low on fuel. The user with headset 4000 may walk to kitchen 6319a and open refrigerator 6337a. The user may pour a glass of orange juice and take a drink. Camera 4022a-b records the activity and sends to house controller 6305a and central controller 110 for communication to the virtual game which may increase the fuel level for the user.
In various embodiments, headset 4000 in house 6300 may be used by a parent to incentivize a child to take out the trash in order to earn game points or unlock game rewards. In some embodiments, a parent in kitchen 6319b may alert a child that it is time to pick up the toys in room 6325. The parent may initiate the communication through headset 4000 by using an established command saved in data storage 4057 and selecting button 4030a-b or verbal request for the child through microphone 4014 (e.g., ‘pick up toys’). The request is sent to house controller 6305a or central controller 110 which transmits the request to the child's headset device 4000. The headset may light up on boom lights 4044 (e.g., blue), vibrate using the vibration generator 4080, make a beep sound in speaker 4010a-b, or show a text message on display 4046 (e.g., ‘pick up toys’). The child may begin to pick up the toys from room 6325. This activity may be recorded on the child's headset 4000 through forward facing camera 4022a-b. When the toys are picked up, processor 4055 may recognize this and communicate with house controller 6305a or central controller 110 to the child's favorite game. The child may be rewarded by their favorite game with extra play time, extra avatar lives or more game tokens to be used to unlock other game rewards, providing motivation to complete the chore and a way to make an unpleasant task fun.
Schoolwork
In some embodiments, headset 9000 in house 6300 may be used to observe a child doing homework as a way to check progress and provide assistance by a parent, teacher, tutor, mentor or other person skilled in the subject. A child with headset 9000 may try to complete multiplication problems in room 6321f. Camera 9090 may be pointed toward the homework to observe the child solving the math problem. A parent sitting at work with headset 4000 and projector 4076 may display the video of the child completing their math homework on the wall. As the child works the multiplication problem, the parent notices the child is not performing the right calculation and is getting frustrated. The parent may speak to the child using microphone 4014 giving helpful tips to complete the math problem. The child listens to the parent through speaker 4012a-b and makes the necessary corrections. In some embodiments where there are multiple children doing homework, the parent with headset 4000 may speak into microphone 4014 and ask the 4055 processor to move the display 4046 and projector 4076 to the next child. This may be in the form of stating the child's name or a general command such as ‘next person’. The parent may also ask for one child's homework to be displayed on the wall from projector 4076 while a different child's homework is presented on display 4046 allowing for the parent to observe and assist both children at the same time.
Homework problems can be projected on walls, speak out loud and the software tells the child if they got the answer correct.
In various embodiments, headset 4000 camera shows you the workbook page your child is working on.
In various embodiments, headset 4000 allows a tutor to speak to a child and walk them through a tricky problem (e.g., as described above).
In some embodiments, headset 9000 in house 6300 may improve the performance of an individual through recording and playback. Headset 9000 records an assignment of a student preparing for a public speech on Abraham Lincoln in room 6321d. The student desires to practice the speech for review and feedback. Camera 9090 is pointed to the students face and the speech is delivered. Headset 9000 with processor 9055 and storage 9057 record the speech. The student initiates playback of the speech and watches the performance on display 9046. The child may want to display the playback speech on wall 6331e from projector 6367f from house controller 6305b and central controller 110. The processor in housing 9008 interprets the speech and offers helpful suggestions (e.g., slow down at minutes 1-2, look into the camera, use more inflections) through speakers and display 9046 or on wall 6331f from projector 6367g. The student makes the adjustments and delivers the speech again. This time, flawlessly. The boom lights 9044 display flashing green and display 9046 display a congratulatory comment (e.g., ‘great delivery, you are ready’). The speaker 6355h may play a song and provide congratulatory comments.
In some embodiments, using headset 4000 in house 6300, a parent may want to verify that their child is completing a musical homework such as doing scales with a piano. The child may use headset 4000 to capture video and audio and store it for later review by a parent on data storage 9057.
In some embodiments, students playing musical instruments may be expected to practice daily for a set period of time. If the parent is not in the room, it may be difficult to confirm that the practice actually took place. In various embodiments, using headset 4000, the child begins playing scales on the piano. Camera 4022a-b and microphone 4014 record the practice and save it on data storage 4057. When the parent arrives home from work, they inquire with the child about their piano practice and ask to see the video and hear the audio. The student shares the video from headset 4000 by selecting button 4030a-b and transmitting to the parent's headset 4000 through house controller 6305b and central controller 110. The parent may request the video playback be shown on display 4046 to observe the practice or wall 6331d from projector 6367d.
In some embodiments, a child may want to learn to draw polygons. Headset 4000 can use projector 4076 to project an outline of a shape which the child can trace. Camera 4022a-b can take pictures of the child's work and along with processor 4055 determine how well the child was able to trace the shape. Headset 4000 can provide feedback through the projecting words or pictures to indicate performance or by providing spoken feedback via headset speakers 4010a-b, or by providing other forms of feedback such as tones, music, or other projected images such as stars, flashing lights, trophies, or any other type of reinforcing image.
In some embodiments, headset 4000 can track and record the time a child spends on homework questions, and provide the data to a teacher. In various embodiments, headset 4000 has one or more lesson plans stored in a data storage device, such as a list of ten math questions along with the answers. When the child requests initiation of the math lesson, headset 4000 projects the first of the ten math questions onto a wall in front of the child. The child works out an answer and speaks the answer into microphone 4014, with processor 4055 determining whether or not the answer was correct. If the answer was correct, projector 4076 displays the second math question and calculates how much time elapsed between the projection of the first question and the projection of the second math question. The data can be summarized in various ways, including the set of problems that take the longest to complete, or the set of problems that have the highest number of incorrect answers by a class, which can be used by a teacher to focus extra help in the areas most needed.
In various embodiments, the walls of a house could be used to create immersive educational games. In some embodiments, one or more wall mounted projectors 4076 project regional geographic maps on one or more walls of the house. Central controller 110 may then identify a target city such as Tokyo, and audio in headset 4000 tells the child through speaker 4010a to “find Tokyo.” The child wearing headset 4000 then walks through the house looking for Tokyo on one of the walls. When the child touches the spot on the wall which shows Tokyo, it can be confirmed by camera 4020 of headset 4000, and that confirmation can be sent to central controller 110 for storage. In some embodiments, when she touches Tokyo happy sounds are produced, or a song is saved to headset 4000 for later listening. In some embodiments, central controller 110 asks the child to answer more complicated questions such as requesting that the child locate the city in Japan with the largest population, find the southernmost country, find a large mountain range, find the city that was buried in ash from the explosion of Mount Vesuvius, or find the cities (in order) that served as the capital of the United States.
In some embodiments, a parent may want to push a reminder or alert to a child or another person—such as reminding a child to stop playing games before bedtime, telling them to come to dinner, or limiting play time. In one embodiment, a parent in kitchen 6319a needs to alert a child in room 6321b that it is time for dinner. The parent initiates the communication through a peripheral (e.g., mouse, keyboard, headset) by using an established key command or verbal request for the child through microphone 6357a. The parent enters the communication request in the peripheral device or preselects a common command (e.g., ‘Stop playing’, ‘Bedtime’, ‘Time for dinner’, ‘Do your homework’). The request is sent to house controller 6305a or central controller 110 which transmits the request to the child's peripheral device. The peripheral device may light up, vibrate, make a sound or display a message based on the preference that the child has established for requests received in room 6321b. The child may respond to the request with pre-selected responses (e.g., ‘OK’, ‘In a few minutes’, ‘No’, ‘Already done’) or enter their own response in the peripheral device or through microphone 6357c. The response is sent to home controller 6305a or central controller 110 and transmitted to the parent's peripheral device for alerting. The response could also be provided to speaker 6355b in kitchen 6319a.
In various embodiments, an individual or system may want to push communications to a person or house without the need for a response. For example, a parent in house 6304 may want to provide the teenagers coming home from school a chore list or schedule for the evening. The parent may use their peripheral device (e.g., mouse, keyboard, headset) to push the chore list to the teenagers. When a child enters house 6302 and is detected by identification reader 6308b, projector 6367e in kitchen 6319b displays the chore list or evening schedule for the teenager(s) identified by the identification reader. In another example, a family in house 6302 may subscribe to news or weather applications for alerts. In the case of weather alerts, house controller 6305a and central controller 110 are informed of an impending thunderstorm, such as by receiving information from weather sensor 6375a. House controller 6305a may push update information and messages to peripheral devices, projectors 6367a-c, speakers 6355a-d, tables 6335a, smart board 6333, changing light colors for alerts to color lighting 6365a-c, or room lights 6363a-c. In another example, communication within the home to various individuals may be set-up to be personalized for each person's daily routine. Using peripheral devices, player 1 in room 6321c may establish their wake-up time as 0600. At 0600, the light 6363c may begin to slowly illuminate, projector 6367b displays a sunrise over a serine beach on the wall, and speaker 6355e plays sounds of the ocean. Player 2 in room 6321a may want a loud sound from speaker 6355d to sound at 0600. Lastly, the parents in 6321b may want the house filled with the smell of freshly baked cinnamon rolls from smell generator 6371 to get the family enticed to get out of bed at 0600.
There are times when parents need to be alerted of the activities of their children. In various embodiments, parents and children with connected devices (e.g., mouse, keyboard, headset) can establish parameters (e.g., purchase limits, types of purchases) when a push alert can be sent to the child. An example may be for online game purchases. In home 6302, a child may wish to purchase ancillary add-ons for a game, costing the child a significant amount of money. A child in room 6321b may initiate a payment via a peripheral device (e.g., mouse, keyboard, headset), which the device communicates to home controller 6305a which in turn alerts the parent's peripheral device. Display 6360a, table 6335a, and smart board 6333 may also display a message(s) of the requested purchase. Speakers 6355a-e may also provide an audible alert (e.g., cash register sound) for the payment request approval. The parent can initiate approval or denial via the enabled user device, via verbal approval through a microphone 6357a-e, or indicate approval by selecting a response displayed on table 6335a or smart board 6333. The response is sent to the home controller 6305a and/or central controller 110. The child is informed of the parent's decision via the peripheral device, audible alert, via speaker 6355e, color lighting device 6365c (e.g., it displays red if denied and green if approved) or lights 6363c (e.g., flashing for denied and solid for approved). If approved the purchase can take place, otherwise it is blocked. In a similar manner, certain games or content with explicit ratings may be prohibited by the parent. The connected devices may be configured to block content. If a child attempts to access this content or game, the parent's peripheral device provides as audible message (e.g., ‘non-approved access’), or a message is provided via speakers 6355a-e, or an alert is displayed on table 6335a or smart board 6333 (e.g., ‘non-approved access for room 6321c‘ or child’Karen’) is received via home controller 6305a or central controller 110 for approval or denial. The parent is informed and can take appropriate action. In the case of denial, access to the content is prohibited and the device(s) may also be locked until reset by the parent.
In various embodiments, multiple people may work in the same electronic document updating content, or a team of players may want to control various aspects of a game or game avatar at the same time. For example, player 1 in house 6302 in game area 6325 initiates play of a game with player 2 in house 6304 in living room 6315b. Player 3 is located in house 6304 in room 6321f. Each player selects a portion of the game or game avatar that they want to control using their peripheral device (e.g., mouse, keyboard, headset). The selected portion is transmitted to the other players via house controller 6305a-b or central controller 110. Player 1 selects the movement of the game avatar (e.g., the legs), player 2 selects the weapons to be used by the game avatar (e.g., guns, arrows, rocket) and player 3 selects the terrain (e.g., desert, forest, ocean floor) to be used and the environmental conditions (e.g., hot, humid, cold, overcast, rainy). During the game each player's peripheral device is alerted via house controller 6305a-b and/or central controller 110 of the selections made. Player 1 may choose to move the avatar faster through the terrain and player 3 may hear (through speakers 6355h) faster footsteps of the game avatar, creating excitement in the game. Player 3 may decide to change the environmental conditions by moving the game avatar to the desert using their peripheral device. In this case, house controller 6305b and/or central controller 110 receive a signal from the peripheral device of the environmental change. House central controller 6305b and/or central controller 110 inform players in home 6302 and 6304 of the change via house controller 6305a-b. House controllers 6305a-b communicate with the air conditioning units 6373a and 6373c and turn up the heat in game area 6325 for player 1 and living room 6315b for player 2 to mimic hotter desert conditions while the game is played. In addition, shade controller 6369b and color lighting 6365b are notified of desert conditions via home controller 6305a and/or central controller 110. The shade controller 6369b opens the blinds and the color lighting devices 6365b illuminate more light for player 1. Windows 6354a-b for player 1 may also become more transparent—allowing more light if the game is being played during sunny conditions. Player 2 in living room 6315b may have pictures and videos of desert conditions projected on the walls with projector 6367d making game play more realistic in the room. Desert sounds (e.g., wind blowing, rattlesnakes, vultures flying) may also be heard from speaker 6355f for player 2 in living room 6315b. In a similar manner, player 2 may choose to use a rocket to launch the game avatar weapon from their peripheral device during the game. When this happens the house controller 6305b or central controller 110 receives the message and transmits it to player 1 in house 6302 via house controller 6305a and central controller 110. Game area 6325 for player 1 with speakers 6355a-c may make a launching and exploding sound. A flash of light to mimic an explosion (e.g., red, orange, bright white) may be generated from color lighting device 6365a. For player 3, the speaker 6355h in room 6321f may also make a launching and explosion sound. There may be a desire for players to be virtually present in the room with another player. In the case of multiple players, player 1 in game area 6325 may request virtual access to player 2's living room 6315b using peripheral devices. If player 2 accepts the request using their peripheral device, the image of player 1 collected from camera 6352b is sent through house controller 6305a-b and central controller 110 to player 2's projector 6367d. The image of player 1 is displayed on wall 6331d of player 2 in living room 6315b. In another embodiment, player 1 may want to impede the game progress of player 2 by inhibiting his peripheral device. Player 1 may have achieved a certain level during the game which gives him the ability to request/take control of another player's peripheral device. Player 1 sends a command through their peripheral device for device control through house controller 6305a and central controller 110. Player 2 receives the command from central controller 110 through house controller 6305b. Player 1 may begin to control the movement, speed, color, sounds, and images of player 2's game character for a period of time during game play. In addition, player 1 may also control elements of house 6304 during this time by, for example, adjusting the color of a room with color lighting device 6365d, sounds from speakers 6355f, brightness of light 6363e and video/image on the walls with projector 6367d. Furthermore, refrigerator 6337b may be locked by player 1 to prevent snacking during play and interruption of the game. This interaction of players through control and collaboration provides a more socially connected gaming experience for players 1-3.
In various embodiments, members of a family or friends may want to recognize someone for an accomplishment or an act of kindness. For example, family members eating dinner in house 6302 dining room 6317a may want to recognize a child who just received an award at school. The parent was notified by the school on their peripheral device (e.g., mouse, keyboard, headset). The parent may select the child to be recognized on their peripheral device or other devices such as the table 6335a or smartboard 6333. Once all family members are seated in chairs 6329d, the parent prompts the initiation of child's recognition via the house controller 6305a or central controller 110 using peripheral devices. At this point, camera 6352b recognizes where the child to be recognized is sitting, and projector 6367a points to the child and illuminates a spot light on the child. Speakers 6355a-c begin to play celebration music, the child's favorite scent (e.g., birthday cake, pizza, popcorn) begins to emit from smell generator 6371 and the room lights up with varying colors (e.g., red, blue, pink) by color lighting device 6365a. In some embodiments, a child's peripheral device (e.g., mouse, keyboard, headset) may light up or provide an audio message congratulating a child on his or her achievements. In some embodiments, central controller 110 stores packaged offerings of celebratory messages with coordinated signals to speakers, displays, projectors, smell generators, and peripheral device screens for many occasions. For example, a birthday package offering might include music to be played via speakers, a virtual birthday cake on a display, customizable text messages for projection, and cake smells directed to smell generators.
In one embodiment, player 1 in house 6304 room 6321d wants to play a game with his friend (player 2) in house 6302. In this example, player 2 is not yet at home. Player 1 notices that not only is his friend (player 2) not online, but has not yet entered house 6302. This information is determined from one or more of identification device 6308a, motion sensor 6350a, and camera 6352a. House controller 6305a relays this information to central controller 110 which then sends the information to player 1 in house 6304 via house controller 6305b. Since identification device 6308a (or motion sensor 6350a or camera 6352a) has not identified player 2 as entering house 6304, this information can be sent to player1. Once player 2 enters house 6302 and the identification reader 6308a (or other devices) is alerted, this information is sent via house controller 6305a and central controller 110 to house 6304 via house controller 6305b. Player 1 may be alerted that his friend has arrived home through his peripheral device, speaker 6355h (via a verbal alert that friend is home) or projector 6367g (e.g., projecting a picture of player 1). Play may once again be initiated.
There may be times when a game player wants to prepare house 6302 for game play in advance of actually being in the house. In some embodiments, for example, a player is at school and decides that they want to play immediately when they arrive home, but need the home conditions to be ready. The player may use their peripheral device while away from the home (e.g., mouse, keyboard, headset) to initiate the settings and conditions of house 6302 prior to entering the home. The settings and activation of devices occurs through house controller 6305a (if near the range of the home) or central controller 110 with authentication of the player's peripheral device. The player may wish to set the temperature of the house to 70 degrees at 2:00 pm using air conditioner 6373a. The room lights 6363a-b may be set in living room 6315a and brought to a low illumination level when the player is recognized as entering house 6302 using identification reader 6308a or camera 6352a. Furthermore, if the player enjoys a cup of hot coffee prior to game play he may set a coffee machine (not shown) in kitchen 6319a to prepare a cup of coffee upon identification of entry in house 6302. The player may also enjoy a fresh smell of the forest in house 6302 during game play and the smell generator 6371 may produce this scent just prior to the players arrival at house 6302, with the arrival time estimated based on a GPS signal from the player's headset and a calculation of the distance yet to be traveled and the current speed of the player. Display 6360a may also be set to turn on when the player enters house 6302 and is identified by identification reader 6308a or camera 6352a. The player's friend may be in house 6304 living room 6315b. House controller 6305a or central controller 110 receives confirmation of the entry of the player in house 6302 and initiates activation of camera 6352d to display the video and image of the player's friend on the smart board 6333 or display 6360a of house 6302 to immediately engage in conversation and play when the home is entered. These embodiments allow for pre-setting of conditions for day and time based on the preferences of the player(s) and provide for nearly immediate play and communication once the home is entered making for a superior gaming experience.
Referring to
Sensor identifier field 7302 may store an identifier (e.g., a unique identifier) for a particular sensor (e.g., for a sensor in house 6300). Sensor type field 7304 may store an indication of a type of the sensor (e.g., camera, microphone, motion sensor, etc.). Sensor location field 7306 may store an indication of a location of the sensor (e.g., an indication of a room, surface, wall, etc.).
Authorized user field 7308 may store an indication of a user who will receive sensor data, view sensor data, view some result or transformation of sensor data, and/or who will otherwise be privy to sensor data. In various embodiments, this may be a first user who monitors the home of a second user so that the first user may be alerted when the second user is available to play a game or otherwise connect.
Subject field 7310 may store an indication of a user who is the subject of a sensor. A subject may be a person detected by the sensor, a person who triggers a sensor, a person identifiable by sensor data, and/or anyone who contributes to the generation of sensor data. In various embodiments, subject field 7310 may include animals, objects (e.g., readable documents; e.g., valuables), and/or other items.
In various embodiments, fields 7308, 7310 may define situations or circ*mstances that impact the configuration (i.e., resolution) at which a sensor will be set. For instance, it may be desirable to set the resolution of a sensor depending on who is viewing sensor data. A sensor might be set at a higher resolution if a more trusted individual is viewing the data, and at a lower-resolution if a less trustworthy individual is viewing the data. It may also be desirable to set the resolution of a sensor depending on who is the subject of the sensor. For example, if a child is walking in front of a camera, it may be desirable to set the camera at lower resolution to protect the child's identity. Also, if valuables are being carried in front of a camera, it may be desirable to set the camera at a lower resolution so as not to encourage theft.
In various embodiments, there may also be certain time periods when it is preferable to, e.g., reduce the resolution of a sensor (e.g., at night when occupants of a home may be in pajamas).
Fields 7308, 7310 define circ*mstances that impact sensor configuration, according to some embodiment. However, it will be appreciated that various embodiments contemplate other possible criteria or circ*mstances that may impact sensor configuration. For example, environmental conditions (e.g., ambient light levels; e.g., ambient noise levels) may make it desirable to alter a sensor's resolution. For example, in conditions of low lighting, a sensor's light sensitivity may be increased.
Resolution field 7312 may store an indication of a resolution of a sensor. Thus, for example, sensor sid900437, a camera listed in table 7300, is to be set at a resolution of 480p if footage from the camera will be visible to authorized user u905598 (field 7308), and if a subject of the footage will be user u755419.
Sample rate field 7314 may store an indication of a sample rate of a sensor. Example rates may be expressed in terms of frames per second (e.g., with a camera sensor), kHz (e.g., with a microphone), Hz (e.g., with a motion sensor), or in terms of any other units. In various embodiments, a higher sample rate may correspond to better detection, better recognition, etc.
Sensitivity field 7316 may store an indication of a sensitivity of a sensor. A sensitivity may refer to a minimum level of input that can be detected. For example, in the case of a camera (or other light sensor), a sensitivity may refer to a minimum level of ambient lighting required for some given level of performance (e.g., for a 70% recognition rate). A camera may also use a standard measure of sensitivity, such as an ISO number. In the case of a microphone, a sensitivity might refer to a minimum sound volume that can be detected, and may be measured in decibels, for example. In the case of a motion sensor, a sensitivity might refer to a minimum weight of a subject or object that can be detected, and may be measured in pounds, for example. In various embodiments, a sensitivity may take any suitable meaning, and may have any suitable units.
Although fields 7312, 7314, and 7316 represent some parameters of a sensor that may be adjusted, various embodiments contemplate that other parameters of a sensor may also be adjusted.
In various embodiments, circ*mstances and configurations (e.g., resolutions) specified in table 7300 may be defined by a user (e.g., by the owner of a particular sensor; e.g., by the owner of the property where the sensor is located). In various embodiments, there may exist default circ*mstances and configurations that may be overridden, if desired, by a user.
Referring to
Sensor identifier field 7402 may store an identifier (e.g., a unique identifier) for a particular sensor. Sensor trigger field 7404 may store an indication of a trigger that caused a sensor configuration to change. In various embodiments, the trigger is what led to the configuration subsequently listed (i.e., in fields 7406, 7408, and 7410). As described with respect to
Updated resolution field 7406, updated sample rate field 7408, and updated sensitivity rate field 7410 may store, respectively, an updated sensor resolution, an updated sensor sample rate, and an updated sensor sensitivity, following the occurrence of a trigger.
Configuration duration field 7412 may store an indication of the time period (e.g., start and end times) during which the configuration was in effect. If the configuration is currently in effect, field 7412 may store only a start time.
Referring to
In various embodiments, a room could be part of a group of several meetings that are all used by a single meeting. For example, one meeting might be split over two rooms in different countries so as to avoid too much travel between locations for a meeting.
Room identifier field 6402 may store an identifier of a room in which a meeting is scheduled to occur. The room may be a physical room, such as a conference room or auditorium. The room may be a virtual room, such as a video chat room, chat room, message board, Zoom call meeting, WebEx call meeting, or the like. In some embodiments, a meeting owner or central controller 110 may switch the room location of a meeting, with the record stored in room ID field 6402 updated to reflect the new room.
Address field 6404 may store an address associated with the room. For example, a room may be located at 456 Gold Street in New York, NY. While this may provide only a high-level designation of the location of a particular room, in some embodiments this information is helpful to employees or contractors who are visiting a meeting location for the first time and need to know how to find the building itself first.
Building field 6406 may store the name of a building within a group of buildings that host meetings. For example, this field might store ‘Building 1’ to indicate that of the eight buildings in a corporate campus, this meeting room is located in Building 1.
Floor 6408 may store an indication of the floor on which the room is located. Room number 6410 field may store a number associated with the room, such as room ‘486’. Such room numbers might be added to stored floor plan maps of a company building, allowing meeting attendees to quickly associate the room number of a meeting with a particular location on a digital map that might be sent to their user device such as a smartphone prior to the start of a meeting.
Room name field 6412 may store a name for a room. A meeting room may be descriptive of the location, such as the ‘Casey Auditorium’, so as to make it easier for meeting participants to quickly understand where the meeting room is located.
Room area field 6414 may store the square footage of the room. In some embodiments this may allow central controller 110 to approximate the number of people that may comfortably fit within the room.
Room height field 6416 may store the height of the room. This could be an average height, or a range of the highest to lowest points in the room. For example, a room might be ‘10 feet‘high or’8 to 12 feet’ high.
Capacity field 6418 may store a capacity limit of the room, such as a capacity of 300 people. In one embodiment, this capacity level is determined by the central controller based on data from room area field 6414.
Energy usage field 6420 may store an amount of energy used to heat or cool the room.
This could be a daily average derived from annual totals, or it could be based on actual energy use by day. Energy use would generally be more for larger rooms, such as the ‘34,000 BTU’ requirement for room ID ‘rm703’. Energy usage data stored in this field may be updated as weather changes occur (e.g., a cold snap may expect to increase energy requirements by 20% in order to achieve a comfortable room temperature) or if new air conditioning equipment is installed.
Sun exposure field 6422 may store the effect of window sizes and sun angles on the room. For example, ‘rm486’ may have ‘high direct’ sunlight at certain hours of the day which may cause room temperatures to rise at that time.
Temperature control field 6424 may store the level of control which users have over room temperatures. In some cases, users may have no control at all, which may make the room less desirable for hosting meetings when outdoor temperatures are very high or very low.
Room setup field 6426 may store the way in which the room is typically set up. For example, the room may be set up in ‘classroom/lecture’ style—which may be good for presenters providing educational materials, though that style may be less effective for brainstorming.
Tables field 6428 may store the number and type of tables in the room. For example, a room may have ‘6 rectangular tables’ which are ‘movable’. In some embodiments this may be an ideal set up for meetings in which participants need to break up into small groups at some point during the meeting.
Number of chairs present field 6430 may store the number of chairs that are supposed to be present in the room. This information is useful when trying to find a room for a particular number of participants. In various embodiments, the chairs are peripheral devices which are in communication with central controller 110, and the chairs may update their room location (determined via GPS or other location system) so that that central controller 110 may update the number of chairs in a room with current and updated information.
Last cleaned date/time field 6432 may store the date at which the room was last cleaned. In various embodiments, central controller 110 could send a request for facilities personnel to clean up a room when it has been more than five hours since the last cleaning.
AV status field 6434 may store an indication of whether or not the AV system is working or is in need of repair. For example, this field may store that ‘rm799’ is currently experiencing ‘flicker on the screen’. This status could prompt central controller 110 to send a signal to AV technicians to schedule a servicing call for this room location.
AV configuration field 6436 may store a meeting type that is most appropriate for a particular room. For example, ‘rm703’ has an AV configuration of ‘Learning’, indicating that in some embodiments AV equipment in the room can support learning meetings in which one person is generally giving a presentation or lecture to a relatively large number of users. For example, the room may be equipped with a handheld microphone and flip charts.
AV quality field 6438 may store an average quality level of the AV equipment in the room. For example, a room might have an AV quality score of 5 out of 10 based on quality scores of the projector and the speakers in the room. In some embodiments, AV quality scores may come from users answering survey questions to gather feedback on the level of AV quality. In one embodiment, a meeting survey could include questions relating to AV equipment and forward the user's answers to central controller 110 where they can be aggregated into an average score for storage in field AV quality 6438 of room table 6400.
Acoustics ratings field 6440 may store an average score representing the acoustic quality of the room. This might be useful to users looking for a room in which music is being played as part of a meeting, or users in an educational setting looking for a meeting room in which to practice a musical instrument.
Whiteboard status field 6442 may store the current condition of one or more whiteboards in a room. For example, whiteboard status might be ‘fair, some permanent marks’ or ‘good, 3 markers left’. This could allow a user looking to book a meeting room for a brainstorming session to avoid rooms with whiteboards that are in poor condition. Many meeting rooms do not include whiteboards as part of the cleaning rotation, and thus marks left on the boards tend to become very hard to wipe off as they age. This can be very frustrating to a meeting facilitator who might walk into a room a few minutes before the scheduled start time, only to realize that the whiteboards are almost impossible to use in the current condition.
Catering availability field 6444 may store an indication of whether or not the meeting room can have catering service for meals, snacks, beverages, deserts, coffee, etc. In various embodiments, catering availability may include the ability to select from an approved set of local restaurants who deliver to the meeting room and have a corporate account with the company. Catering availability could also include information regarding the hours during which catering is available, or indicate what employee level is required in order to make a catering order.
Wheelchair accessibility field 6446 may store an indication of whether or not the room is accessible to users in wheelchairs. In some embodiments, this includes a description of what the access looks like, such as a description of ramps, their materials, and the angle of the ramp. In other embodiments, this field could also store other accessibility information such as whether or not there are places in the room to store the wheelchair or if there are desks in the room that can accommodate a wheelchair.
Referring to
In various embodiments, peripherals, or other equipment may include video equipment, microphones, phones, display panels, chairs (intelligent and non-intelligent), and tables.
Room identifier field 6502 may store an identifier of a room in which a meeting is scheduled to occur. The room may be a physical room, such as a conference room or auditorium. The room may be a hybrid room, such as a physical room with some participants joining via video chat room, chat room, message board, Zoom® call meeting, WebEx® call meeting, or the like.
Peripheral ID field 6504 may store an identifier of each peripheral currently in the room. Location in room field 6506 may store the location of a peripheral within a meeting room. The location may be determined, for example, by a peripheral device locating itself via GPS or other suitable locating technology and then transmitting this location back to central controller 110. For example, the peripheral may be identified as in the ‘corner of the far right wall‘ or in the’center of the north wall.’ In other embodiments, the location data is presented on a digital map so that the exact location in the room is immediately clear. In various embodiments, this peripheral location data may be provided to a user looking for that peripheral. For example, a meeting participant could be sent a digital map onto her user device for display of the map.
In various embodiments, peripheral or equipment models may be stored.
In various embodiments, training videos for using peripherals or equipment of a room or of any other part of system 100 may exist. Videos may be stored, e.g., in asset library table 1900, or in any other location.
Referring to
Vendor ID field 6602 may store a unique identifier for each stored vendor. In some embodiments, these stored vendors are all company approved vendors that are known to perform a specific service. Name field 6604 may store the name of the vendor, such as ‘Machine Cleaning Express’ or ‘Swift Copy Repair’. In some embodiments, vendors might include vendors supplying services for a meeting room such as supplying equipment, chairs, tables, cameras, lights, office supplies, training, etc. In some embodiments, vendors may offer services mediated by a remote person who delivers the services through a headset 400 worn by an employee of the company, potentially decreasing the costs of vendor services.
Category field 6606 may store the type of service provided by the vendor. These categories could include ‘cleaning’, ‘printing’, ‘repair’, etc. Price field 6608 may store an average cost per hour for the service. This could be used by central controller 110 to generate total service cost estimates.
Min time field 6610 may store a minimum amount of time for a particular service call.
For example, ‘Machine Cleaners Express’ requires 90 minutes per service call.
Ratings field 6614 may store a numeric or level rating for the vendor, such as ‘4.5’ on a five point scale. In some embodiments such ratings could be generated by user feedback through a user device connected to central controller 110 and then aggregated and stored in ratings field 6614. Stored ratings could also be stored and presented individually, so that ratings data for a vendor includes many comments from users of the service. Website field 6616 and phone field 6618 may store contact information for vendors so that requests can be placed or followed up on.
In accordance with some embodiments, the GUI may be made available via a software application operable to receive and output information in accordance with embodiments described herein. It should be noted that many variations on such graphical user interfaces may be implemented (e.g., menus and arrangements of elements may be modified, additional graphics and functionality may be added). The graphical user interface of
With reference to
In some embodiments, the user may select from a menu 6720 which displays one or more different modes of the software. In some embodiments, modes include ‘game session setup’, ‘game selection’, ‘feedback to team members’, ‘request for game tips/coaching’, ‘feedback for advertisem*nts, etc.
The app may show questions for a game team leader, such ‘who are the players in this game session?’ 6702. In this example, answers have been provided at 6714. Other questions may include, ‘do you want alerts when they are ready to play?’ 6704 (e.g., do you want a light on your mouse to light up when all players are determined to be ready to play), ‘are all team members playing in the same location?’ 6706 (e.g., will communication channels need to be set up between one or more of the players), ‘do you want voice chat via mouse enabled?’ 6708 (e.g., will players want to chat amongst the team members using voice capabilities in their mouse), ‘do you want game sounds to follow movement in the house?’ 6710 (e.g., will players need to be tracked via sensors in their house so that nearby speakers can provide ongoing game sounds as they move from one location in a house to another) and a question about whether the game team leader wants to ‘allow mouse advertising during the game?’ 6712. In these examples, yes/no answers are provided by the game team leader. For example, this game team leader has indicated that she wanted voice chat via mouse enabled 6708. In various embodiments, game session setup may include responses for a moment in time, provided once during a game, provided at a few fixed times during the game, or variations thereof. As will be understood, there are many different questions that might be asked of a game team leader or other game participants. In one embodiment, central controller 110 stores a list of potential questions, and game team leaders can pick from this list of questions in setting up the game session. In some embodiments, feedback may be requested from team members such as ‘did you enjoy the game session?’, ‘would you like to see more games from this publisher?’, ‘are there other game players that you think should be invited to the next game?’, etc. Feedback from users could also be more open-ended by giving them a chance to make any kind of comment. For example, a player might indicate that they are ‘confused’, ‘distracted’, ‘not having fun playing on this game territory’, ‘feel like their voice is not heard when it comes to game strategy decisions’, etc. In other embodiments, the app could solicit suggestions from players. Players might indicate that they have suggestions via the app, such as by suggesting that ‘the game is too complex’, ‘we should take a break now’, ‘we need a new game strategy’, ‘we should be playing in the same location rather than connecting virtually’, etc. In some embodiments, users of the app can cast votes during a game or add notes to voting results. In other embodiments, users provide summary evaluations at the conclusion of a game, such as a one to five star rating of a game, or a one to five star rating of whether or not the game session was fun. Additional general comments could be provided by users at the conclusion of the game, such as an evaluation of the success of the game session, or an indication of whether the game team leader encouraged team members to speak.
In some embodiments, the app could provide notifications to users as to game location changes, time changes, player changes, cancellations, etc. Various embodiments contemplate that any other feedback data, or any other input data from a peripheral device, may be shown, may be shown over time, or may be shown in any other fashion.
In various embodiments, the device running the app (e.g., a smartphone or tablet), may communicate directly with central controller 110 and directly with peripheral devices (e.g., via Bluetooth®; e.g., via local wireless network), or may communicate with the corresponding peripheral devices through one or more intermediary devices (e.g., through the central controller 110; e.g., through the user device), or in any other fashion.
With reference to
Map 6800 depicts two buildings 6802 and 6804 with an outdoor area 6806 between them. As depicted in map 6800, buildings 6802 and 6804 each have only one floor. However, in various embodiments, buildings with multiple floors may be depicted. In some embodiments, devices depicted within the map 6800 are under the control of a central controller 110 which may use wired or wireless connections to send commands or requests to various devices and locations within the campus. This allows meeting owners, facilitators, participants, and observers to employ user devices (such as a smartphone) to communicate with central controller 110 in order to command various devices throughout the campus. It will be understood that this layout of a company or educational campus is for illustrative purposes only, and that any other shape or layout of a campus could employ the same technologies and techniques.
The depicted campus layout view includes various devices and represents one exemplary arrangement of rooms, paths, and devices. However, various embodiments contemplate that any suitable arrangement of rooms, paths, and devices, and any suitable quantity of devices (e.g., quantity of chairs; e.g., quantity of cameras) may likewise be used.
In various embodiments, building 6802 represents a factory, laboratory, research laboratory, fabrication facility, experimental facility, sensing facility, monitoring facility, communications facility, storage facility, and/or any other industrial or scientific facility. Building 6802 may include one or more areas where safety and/or intellectual property and/or property are of concern. Building 6802 may include machinery or equipment of a potentially dangerous nature (e.g., saws, lathes, lasers, industrial robots, etc.). Building 6802 may include irritants that may cause damage to organs/tissues (e.g., liver, heart, brain, stomach, eye, skin, nose, ears, lung) and/or dangerous chemicals, such as hydrofluoric acid. Building 6802 may include radioactive materials, radiation, biological hazards, pathogens, etc. Building 6802 may include controlled substances, such as opioids, drugs, drug precursors, etc. Building 6802 may include weaponizable materials. Building 6802 may include potentially hazardous gases, such as carbon monoxide, hydrogen, nitrogen, etc. Building 6802 may include objects or environments at extreme temperatures (e.g., furnaces, e.g., cryogenic storage), which may be potentially hazardous. Building 6802 may include sharp objects. Building 6802 may include dangerous heights, unguarded platforms, or other falling hazards. Building 6802 may include flammable, combustible, and/or explosive objects or materials. Building 6802 may include electrical components or equipment with dangerous voltage and/or current levels. Building 6802 may include high magnetic fields. Building 6802 may include vapors, breathing hazards (e.g., asbestos), etc. Building 6802 may include confined and/or unventilated areas. Building 6802 may include vats or liquids that present drowning or suffocation hazards. Building 6802 may include fragile, delicate, and/or otherwise sensitive items, such as clean rooms. Building 6802 may include sensitive plans, records (e.g., medical records), data, plans for controlled items (e.g., for rocket technology), and/or any other sensitive materials. Building 6802 may include commodities, valuables, and/or other items of value, such as currency, platinum, silver, computer chips, laptops, etc.
For these reasons, and/or for any other suitable reasons, it may be desirable to restrict or control access to building 6802 and/or to any rooms or portions thereof. Where access is granted, it may be desirable to monitor and or limit individuals to whom access is granted. It may be desirable to monitor and/or restrict what items go into building 6802 and/or what comes out of building 6802. For example, users may be forbidden from bringing in backpacks or other items that can conceal objects. It may be desirable to monitor and record occurrences at the building, such as equipment usage, what items were brought in, what items were brought out, who went in, who came out, what someone did while inside, environmental conditions (e.g., temperature, oxygen levels, gas levels, humidity levels, etc.), whether any safety hazards are present, when the most recent cleaning has occurred, what accidents or near accidents have occurred, and/or any other event or situation at building 6802. In various embodiments, it may be desirable to monitor areas outside and/or surrounding building 6802 (e.g., silo 6897, building 6804).
Building 6802 may include multiple tiers or levels of access control. For example, entry into a given room may require separate authorization, even if a user has already been authorized to enter the building and/or a separate room. Individual items of equipment (e.g., machines, computing devices) may require authorization for use. Viewing an item (e.g., a document, a piece of equipment) may require separate authorization. Authorization may be enforced through physical mechanisms, such as doors or barriers with locks (e.g., with electronic door locks). Authorization may be enforced by altering availability of a device or item of equipment. For example, a device may not be turned on unless a user is authorized to work with the equipment. Authorization may also require multiple steps, multiple factors, and/or repeated or continuous renewal. For example, a user's identity must be confirmed through three independent methods before a user is allowed to access a room. As another example, a user must re-verify his identity every 10 minutes in order to continue using a software program. In some embodiments, a user may be continuously authenticated with multiple streams of identifying information produced as the user goes through the day. In some embodiments, every time that a user speaks, headset 4000 verifies the voiceprint and stores an indication of whether or not the voiceprint matched that store with central controller 110. In some embodiments, cameras 6852a-h may take images of a user and determine whether or not an employee badge is worn, and if the badge corresponds to the user associated with the headset. In such embodiments, this continuous authentication enables a central controller 110 to pick up on the identity information that is constantly shed by users throughout the day. In various embodiments, each user output used in an authentication protocol may be transmitted to central controller 110 via a separate communication channel and/or processed with a separate processor of headset 4000.
In various embodiments, headset 4000, another peripheral, another device, and/or any device located within or proximate to building 6802 may facilitate logging, monitoring, restricting access, granting access, and or any other process described herein.
Building 6802 has entrance 6810a and building 6804 has entrance 6810b. The outdoor area 6806 has entrance 6810c. In various embodiments, 6810c is the only means of entry (e.g., permitted means of entry) into the campus from the outside. For example, the outdoor area 6806 may be otherwise fenced-off.
Entrances 6310a, 6310b, and 6310c may be connected via a walking path 6814. In various embodiments, the path may be available for various modes of transportation, such as walking, skating, scooter, bicycle, golf cart, etc.
Inside buildings 6802 and 6804 are depicted various rooms, including such offices as 6816a, 6816b, and 6816c; including such conference rooms as 6824a and 6824b; small conference room 6826; and including kitchen 6830. Various embodiments contemplate that buildings may include other types of rooms even if not explicitly depicted (e.g., gyms, cafeterias, roof areas, training rooms, restrooms, closets and storage areas, atrium space, etc.).
Building 6802 includes reception area 6842a, and building 6804 includes reception area 6842b. In some embodiments, users (e.g., employees, contractors, vendors, visitors, emergency responder, auditors) may be provided with a headset 4000 when entering a reception area, with the headset assigned to the user and registered with central controller 110 for tracking during the day. In some embodiments, users leaving a building may be required to return headsets 4000 to personnel in reception areas 6842a-b, with those headsets 4000 containing records of what that user looked at, where they went (e.g., GPS data), what other users they interacted with, etc.
Building 6804 includes hallway 6844. Map 6800 depicts various cameras, such as camera 6852g which observes the outdoor area 6806, and camera 6352h which observes hallway area 6844.
Inside building 6802 is depicted a research and development area 6860, which contains a government security clearance room 6865, a pathogen lab 6870, and a laser facility 6875. In some embodiments, each of these rooms requires authorization to enter given the safety or secrecy issues involved with entry into the room. There is also depicted a manufacturing area 6880, which contains acid tanks 6885, grinding machine 6890, and clean room 6895. In some embodiments, each of these rooms similarly requires authorization to enter.
Inside building 6804 is depicted a control room 6828 that may be used to house safety personnel, which in some embodiments may be called upon to provide safety training and/or respond to unclean conditions, unsafe conditions, safety hazards, failed authorization attempts, emergencies, etc. in building 6802. In some embodiments, employees can employ a user device (e.g., a smartphone) to provide emergency requests to control room 6828 via central controller 110. In some embodiments, central controller 110 may use images of rooms, facilities, etc. to automatically detect unsafe conditions and alert control room personnel, security personnel, etc. Control room 6828 may include displays 6846a and 6846b which may display still image or video feeds from one or more of cameras 6852a-h, allowing personnel in control room 6828 to monitor activities in building 6802 and 6804. In some embodiments, one or more users 6855a-d are wearing headsets 4000 and sending video feeds from a camera of headset 4000 to central controller 110 which in turn provides that video feed to control room 6828 for display on displays 6846a-b. In some embodiments, an audio feed from headsets 4000 of one or more users 6855a-d may be transmitted to central controller 110 for use by control room 6828, such as for assessing a safety situation near one or more users.
In various embodiments, central controller 110 may detect automatically if an area has hazardous or dangerous conditions, and may thereupon automatically alert the control room 6828, summon crew to the area, and/or take some other action. For example, the central controller may scan video feeds from a particular area (e.g., via a video feed from a user headset 4000) and identify water or hazardous liquids on the floor of a room. In some embodiments, if there has been no cleaning crew in the last 24 hours, for example, then the central controller may summon the cleaning crew to that area.
It will be appreciated that map 6800 depicts an arrangement of rooms according to some embodiments, but that various embodiments apply to any applicable arrangement of rooms.
Motion sensors 6850a, 6850b, 6850c, 6850d, 6850e, and 6850f may be positioned throughout map 6800. In some embodiments, motion sensors 6850a-f capture movements of users 6855a-d throughout map 6800 and transmit the data to central controller 110 for storage or processing, e.g., for the purposes of locating employees, identifying employees, authenticating employees, etc. In some embodiments, motion sensors 6850a-f may transmit data directly to central controller 110. In some embodiments, motion sensors 6850a-f capture data about users entering or leaving building 6802 or 6804 and transmit data to a room controller or directly to central controller 110, e.g., for the purposes of maintaining consistent safety protocols.
Cameras 6852a, 6852b, 6852c, 6852d, 6852e, 6852f, 6852g and 6852h may be configured to record video or still images of locations throughout campus 6800. In some embodiments, cameras 6852a-h capture a video signal that is transmitted to a room controller via a wired or wireless connection for storage or processing. In some embodiments, the room controller may then transmit the video to central controller 110. In other embodiments, any of cameras 6852a-h send a video feed directly to central controller 110. In some embodiments, cameras 6852a-h may be used in authentication protocols, or to determine whether or not an employee (or contractor or vendor) is in an area that they are not authorized to enter. In some embodiments, a meeting owner might bring up the video feed from one or more of cameras 6852a-h during a break in a meeting so that the meeting owner could keep an eye on meeting participants who left the meeting room during a break. Such a video feed, for example, could allow a meeting owner in conference room 6824d to see a feed from camera 6852a to identify that a meeting participant had gone back to building 6802 during the break and was currently standing in hallway 6846a and would thus not be likely to return to the meeting in the next two minutes.
User identification readers 6808a, 6808b, 6808c, 6808d, 6808e, 6808f, 6808g, 6808h, and 6808i are positioned at the entry points 6810a-c and at key access points to restricted areas in industrial building 6802 and serve to identify employees and allow/deny access as they attempt to move through the entry points. For example, user identification readers can be NFC and/or RFID readers to scan an employee badge, a camera to identify the user via face recognition, a scanner to identify a user by a carried user device, a microphone for voice recognition, or other user identification technology. In some embodiments, user identification readers 6808a-i transmit data about user entering or leaving campus 6800 and transmit data to a room controller or directly to central controller 110, e.g., for the purposes of maintaining access to secure rooms. User identification readers 6808a-i can allow or deny access to individual employees by validating their inclusion in tables stored with central controller 110 that contain the lists of employees properly trained to handle the equipment in the general R&D and Manufacturing areas, or in another embodiment, that contain lists of employees that are approved to work on certain projects or work in certain rooms (e.g., laser facility 6875). In various embodiments, user identification readers may grant or deny access to areas of access restricted based on ITAR requirements (e.g., via user identification reader 6808a), pathogen lab 6870 (e.g., via user identification reader 6808b), laser facility 6875 (e.g., via user identification reader 6808c), or areas restricted for any other reason. In various embodiments, these may grant or deny access to areas restricted based on HF acid training levels when a user attempts to access acid tanks 6885 (e.g., via user identification reader 6808d), safe industrial grinder operation levels when a user attempts to access grinding machine 6890 (e.g., via user identification reader 6808e), clean room training level (e.g., via user identification reader 6808f), confined space entry training when attempting to access silo 6897, or areas restricted for any other reason.
In some embodiments, map 6800 may be stored with central controller 110, and could thus be sent to user devices as a way to help users know where restricted rooms are, and to determine a path out of a room if a safety issue requires the user to leave the room. In some embodiments, motions sensors 6850a-f can be used to track and guide employees in their regular duties or in emergency situations. For example, in one embodiment motion sensor 6850d by silo 6897 can update main a database record stored with central controller 110 when an employee enters the confined space, and personnel can communicate via the employee's headset to help them find their way, keep track of time, complete their tasks safely, or accomplish anything else. In some embodiments, the headset can be used to track levels of oxygen, or dangerous gases, or extreme heat or cold, or any other environmental variable, to ensure the employee is safe or warn the employee if conditions become unsafe. In various embodiments, headset 4000 can be used to track the alertness, movements, eyes, or any other aspect of the employee's behavior, and warn if and when an employee begins acting in a way that may indicate they are losing focus, getting drowsy, not getting enough oxygen, or exhibiting any other signs of degraded performance.
Referring to
The depicted room includes lights 6925a and 6925b, which allow for illumination of door access control area 6900. In some embodiments, these lights may be under the control of central controller 110 and can be turned on or off as a way to communicate with users within (or near) door access control area 6900. For example, central controller 110 may direct lights 6925a-b to flash on and off when a user has entered an incorrect numeric code into access control 6910. Such flashing of lights could alert others to approach the user to determine if they need help or to determine if the user is authorized to access door 6905. Color lighting device 6930 may provide additional communication options. In some embodiments, color lighting device 6930 generates a red light which illuminates door access control area 6900 while the laser is currently active. In some embodiments, the depicted room may also include safety equipment such as a fire extinguisher 6970 and first aid kit 6975. In case of an emergency, central controller 110 might direct users to the location of such safety equipment. In some embodiments, central controller 110 directs all color lighting devices to display a green color if that room contains safety equipment.
In some embodiments, the depicted room may also include devices that may be used in the process of authenticating a user in order to determine if the user may gain entrance through door 6905. In some embodiments, motion sensor 6950 captures movements of occupants in door access control area 6900 and transmits the data to central controller 110 for storage or processing, e.g., for the purposes of locating users attempting to open door 6905 or identifying users nearby who may be able to assist in authenticating access to door 6905. In various embodiments, motion sensor 6950 captures data about people entering or leaving door 6905 and transmits data to room controllers or directly to central controller 110. In some embodiments, motion sensor 6950 can be set for a low resolution mode in which only coarse movements may be detected. For example, only movements of large objects may be detectable, such as the movement of one or more people, while movements of smaller objects such as boxes or carts are not detected. Cameras 6955a and 6955b may capture images or video of door access control area 6900. In some embodiments, cameras 6955a-b may be under the direction of central controller 110 and may thus be activated when a user attempts to authenticate himself in order to access door 6905. In some embodiments, central controller 110 receives images from cameras 6955a-b when a user requests authentication to door 6905, and compares those images to stored images of the user in order to determine a degree of match as part of the authentication process. In various embodiments, cameras 6955a-b may be movable, allowing them to be pointed at a particular user, or to zoom in on a particular part of the user such as a face, eye, lips, hands, fingers, hair, tattoos, jewelry, clothing, employee badge, materials with text visible, etc. Central controller 110 may then use one or more of these targets of cameras 6955a-b (e.g., a tattoo and a wedding band) as an input to the authentication process. Projector 6960 may display a message on wall 6980 such as message 6962 “Headset Required.” In some embodiments, message 6962 may be incorporated into an authentication process, such as by asking a user seeking access to door 6905 to type the year he was born into a keypad of access control 6910. In some embodiments, speaker 6965 may be used to provide messages to a user seeking access to door 6905. In some embodiments, such messages could include instructions to the user, such as asking the user to turn and face camera 6955b during an authentication procedure.
In various embodiments, one or both of headsets 6985a and 6985b may be used in an authentication protocol in order for a user to gain access to door 6905. In some embodiments, a user seeking to gain access to door 6905 may be required to be wearing a headset 6985b. His headset 6985b could wirelessly transmit data to access control 6910 or central controller 110, using headset elements like a microphone (e.g., capturing a voiceprint of a spoken password), camera (e.g., capturing an image of his iris for biometric authentication), storage device (e.g., a stored password or cryptographic keys), accelerometer (e.g., identifying characteristics of the user's walking gait), brainwave sensor (e.g., determining an EEG signal), etc. Central controller 110 could also incorporate challenge/reply protocols into the authentication process, asking the user a question via a speaker of headset 6985b such as “what is the name of the meeting that you attended at 10:00 AM this morning?” In some embodiments, headset 6985a of another user within door access control area 6900 may be used in an authentication protocol. In some embodiments, a second user wearing headset 6985a is asked by central controller 110 to yell out a four digit number (e.g., provided by central controller via a speaker of headset 6985) so that a microphone of headset 6985b of a user seeking access to door 6905 picks up the four digit number and relays it back to central controller 110. In this way, the user with headset 6985b can authenticate that they are within yelling range of another user at the company. A camera of headset 6985a may also provide images to central controller 110 of the user attempting to gain access to door 6905.
Referring to
Video ID field 7002 may store a unique identifier associated with a piece of video content. Content summary field 7004 may store a brief description of the video content, such as training video’ or ‘instruction manual’.
Referring to
Location field 7602 may store an address of a user at which weather data is recorded.
Date field 7604 may store an indication of the date on which the weather data was recorded, while time field 7606 may store the time at which the weather data was recorded. Temperature field 7608 indicates the temperature in Fahrenheit at this location 7602, humidity field 7610 stores the percent humidity, and wind speed field 7612 may store the current wind speed in miles per hour.
The type of precipitation field 7614 may store types of precipitation such as rain, snow, hail, etc. Each form of precipitation may store an associated precipitation rate in precipitation rate field 7616, such as 0.15 inches per hour of rainfall or 0.46 inches per hour of snow. Light level field 7618 stores the number of lux, while cloud cover field 7620 provides a percentage of the sky that is covered by clouds.
In various embodiments, weather data could be entered by a user, received from a weather sensor such as weather sensor 6375a of
Referring to
Asset ID field 7702 may uniquely identify audio or video content. Asset type field 7704 may store an indication of the kind of media that is being broadcast, such as a movie, television episode, audio book, and the like. Trigger ID field 7706 uniquely identifies one or more triggers associated with asset 7702, the trigger generating commands that drive user devices to generate additional content. The time field 7708 may store the time at which a trigger is engaged. For example, a trigger might engage at ‘00:36’ minutes into the delivery of audio/visual content. Target output device field 7710 stores the output device (e.g., a color lighting device, speakers, projector) that will be instructed to deliver additional content. Output field 7712 stores an indication of the additional content, such as ‘blue lighting’ or the ‘sound of a thunderstorm.’ Duration field 7714 stores an indication of the length of the additional content, such as ‘90 seconds’ in the example of the ‘blue lighting’ scenario. In various embodiments, the additional content delivered to the user through devices in their house or office adds many creative options for the enhancement of standard broadcast content such as television shows or movies. In some embodiments, a user listening to a murder mystery audio book may encounter a trigger which is associated with a particular paragraph of the audio book which triggers a speaker down the hall from the user to play the sounds of footsteps approaching which makes the content being read more exciting.
Referring to
Live content identifier field 7802 may uniquely identify audio or video content. Live content type field 7804 may store an indication of the kind of media that is being delivered, such as a game environment, streamer channel, sporting event, and the like. Trigger ID field 7806 uniquely identifies one or more triggers associated with live content 7802, the trigger generating commands that drive user devices to generate additional content. The trigger field 7808 may store a condition which, if satisfied, triggers the serving of additional content to a user. For example, a trigger might engage during a sporting event when the ‘home team scores a touchdown.’ Target output device field 7810 stores the output device (e.g., a color lighting device, speakers, projector) that will be instructed to deliver any additional content triggered. Output field 7812 stores an indication of the additional content, such as ‘lighting decreases 75%‘ or the’sound file of team song.’ Duration field 7814 stores an indication of the length of the additional content, such as ‘until game character is out of dark zone’. In various embodiments, the additional content delivered to the user through devices in their house or office adds many creative options for the enhancement of live content such as game environments or sporting events. In some embodiments, a user watching a football game may encounter a trigger when the home team scores a touchdown, with a sound file of the home team song playing for 90 seconds from the user's speakers.
Process Steps According to Some Embodiments
Turning now to
Registering/Applying for a Meeting
At step 7903, a user may set up a meeting, according to some embodiments.
In setting up a meeting, the meeting owner might have to register the meeting or apply for the meeting with the central controller 110. This can provide a gating element which requires meeting owners to provide key information prior to the meeting being set up so that standards can be applied. For example, a meeting purpose might be required before having the ability to send out meeting invitations.
In various embodiments, the Meeting Owner (or Meeting Admin) could be required to apply to the central controller 110 to get approval for setting up a meeting. Without the approval, the central controller could prevent meeting invites from being sent out, not allocate a room for the meeting, not allow the meeting to be displayed on a calendar, etc. This process could be thought of as applying for a meeting license. To get a meeting license, the meeting might have to include one or more of the following: a purpose, an agenda, a designated meeting owner, a digital copy of all information being presented, an identification of the meeting type, an objective, a definition of success, one or more required attendees, evidence that the presentation has already been rehearsed, etc. Permitting may require Meeting Owner to apply a predefined number of points from a meeting point bank—e.g., different amounts of meeting points can be allocated to different employees, roles, expertise, levels once per given time period, with higher levels (e.g., VPs) being allocated more points (and accordingly being able to hold more meetings or meetings with more/higher ‘value’ attendees). Meeting points could also be earned, won, etc.
In various embodiments, the central controller 110 could also review the requested number of people in a meeting and compare that to the size of rooms available for that time slot. If a large enough room is not available, the central controller could make a recommendation to break the meeting into two separate groups to accommodate the available meeting size.
In various embodiments, the central controller could have a maximum budget for the meeting and determine an estimated cost of a requested meeting by using a calculation of the dollar cost per person invited per hour (obtained from HR salary data stored at the central controller or retrieved from HR data storage) multiplied by the number of people invited and multiplied by the length of the meeting in hours (including transportation time if appropriate). Such an embodiment would make the cost of meetings more immediately apparent to meeting organizers, and would impose greater fiscal responsibility in order to reduce the number of meetings that quickly grow in the number of attendees as interested—though perhaps not necessary—people join the meeting. In this embodiment, a meeting owner might be able to get budget approval for a meeting with ten participants and get that meeting on the calendar, but have requests for additional attendees approved only as long as the meeting budget is not exceeded. In various embodiments, the central controller could deny a meeting based on the projected costs, but offer to send an override request to the CEO with the meeting purpose to give the CEO a chance to allow the meeting because the achievement of that purpose would be so impactful in generating business value and shareholder value. Further, the central controller could allocate meeting costs to various departments by determining the cost for each attendee based on the time attended in the meeting.
In various embodiments, requesting a meeting could also require registering any projects(s) that the meeting is associated with. For example, a decision-making meeting might register one or more previously held brainstorming sessions which generated ideas that would serve as good fuel for the decision making session. Additionally, the meeting owner might be required to register any other meetings that will be held in the future that will be related to this meeting.
In various embodiments, meeting requests could require the meeting owner to tag elements associated with the meeting. For example, the meeting could be tagged with “Project X” if that is the main topic of the meeting. It might also be tagged with “Budget Decision” if the output will include a budget allocation amount. Another type of required tag could relate to whether or not legal representation is required at the meeting.
In various embodiments, when a meeting is requested, the meeting owner could be provided with meeting content/format/tips related to the type of meeting that they are trying to set up.
At step 7906, a user may determine meeting parameters, according to some embodiments.
Meeting Configurations
The central controller 110 may offer a number of standard configurations of equipment and software that will make it easier to configure a room.
In various embodiments, a meeting participant or meeting owner can set standard virtual meeting configurations. For example, there could be three standard packages available. Configuration #1 may include microphone type, camera to be used, volume levels, screens to be shared, multiple screen devices and background scenes to be used. Configuration #2 may include only audio/phone usage. Configuration #3 may include any combination of recognized devices to be used. Once settings are established, they may be controlled by voice activation or selection on any mobile or connected device.
In various embodiments, meeting owners can provide delegates with access to meeting set-up types (e.g., Admins).
In various embodiments, a meeting owner assigns participants to meeting room chairs (intelligent and non-intelligent chairs). Intelligent chairs can pre-set the chair configuration based on the person sitting in the chair (height, lumbar, temperature).
In various embodiments, the central controller 110 automatically determines a more appropriate meeting place based on the meeting acceptance (in-person or virtual) to make the most efficient use of the asset (room size, participant role/title and equipment needed to satisfy the meeting purpose).
In various embodiments, a meeting presenter can practice in advance and the central controller 110 uses historical data to rate a presentation and the presenter in advance.
Meeting Right-Sizing
Many large companies experience meetings that start out fairly small and manageable, but then rapidly grow in size as people jump in—sometimes without even knowing the purpose of the meeting. Many employees are not familiar with how large meetings should be, and that the size of the meeting might need to vary significantly based on the type of meeting.
Agenda
In various embodiments, the central controller 110 could understand the appropriate number of agenda topics for a meeting type and recommend adjustments to the agenda. For example, in a decision-making meeting, if the agenda includes a significant number of topics for a 1-hour meeting, the central controller could suggest removing some of the decisions needed and moving them to a new meeting.
Participants
In various embodiments, the central controller 110 could recommend a range for the number of meeting invitees based upon the meeting type, agenda, and purpose. If a meeting owner exceeds the suggested number of invitees, the central controller can prompt the meeting owner to reduce the number of invitees.
Dynamic Right-Sizing During Meetings
Based upon the agenda, the central controller 110 can allow virtual participants to leave the meeting after portions of the meeting relevant to them have finished. A scrolling timeline GUI could be displayed, showing different portions of a meeting as the meeting progresses; e.g., with icons/avatars for attendees currently in, previously in, or expected to join for different sections/portions. Additionally, the central controller can identify portions of the meeting that contain confidential information and pause the participation of individuals without the appropriate permission to view that information.
Recurring Meetings
In various embodiments, the central controller 110 can prompt owners of recurring meetings to adjust the frequency or duration of meetings to right-size meetings over time. The central controller can also prompt owners of recurring meetings whether invitees should still be participating as time goes on. The central controller can auto select time slots based on attendee list calendars, preferences, and/or historical data—e.g., higher measured level of attentiveness/interaction for one or more attendees at different times of day, days of week, etc.
Room Availability
Based upon the availability of larger meeting rooms, the central controller may prompt a meeting owner to reduce the number of participants or break the meeting into smaller meetings. Meetings that require more people than a room can accommodate, the central controller could recommend which participants should be present in the meeting room and those that should be virtual only. For example, if a decision-making meeting is taking place and three decision makers are key to achieving the goals, they should be identified as being physically present in the meeting room. The other participants should only be invited to attend virtually.
Learning Algorithm
Over time, the central controller 110 may begin to collect information regarding the meeting type, agenda items, duration, number of participants, occurrences, time of day, logistics (building location, time zones, travel requirements, weather), health of employees (mental and physical fitness, for example the central controller could recommend smaller meetings during the peak of flu season) and meeting results to provide more informed right-sizing recommendations. In other words, an Artificial Intelligence (AI) module may be trained utilizing a set of attendee data from historical meetings to predict expected metrics for upcoming meetings and suggest meeting characteristics that maximize desired metrics.
Meeting Participant Recommendations
At step 7909, the central controller 110 may suggest attendees, according to some embodiments.
The central controller could take the agenda and purpose of the meeting and identify appropriate candidate meeting participants who could build toward those goals. In various embodiments, the central controller may take any other aspect of a meeting into account when suggesting or inviting attendees.
In various embodiments, given a meeting type (e.g., innovation, commitment, alignment, learning), the central controller may determine a good or suitable person for this type of meeting. In various embodiments, the central controller may refer to Meetings table 5100, which may store information about prior meetings, to find one or more meetings of a similar type to the meeting under consideration (or to find one or more meetings sharing any other feature in common with the meeting under consideration). In various embodiments, the central controller may refer to Meeting Participation/Attendance/Ratings table 5500 to determine a given employee's rating (e.g., as rated by others) for prior meetings.
In various embodiments, the central controller may refer to Employees table 5000 to find employees with particular subject matter expertise, to find employees at a particular level, and/or to find employees with particular personalities. Thus, for example, an employee can be matched to the level of the meeting (e.g., only an executive level employee will be invited to an executive level meeting). An individual contributor level meeting may, on the other hand, admit a broader swath of employees.
In various embodiments, if the meeting is about Project X then the central controller could recommend someone who has extensive experience with Project X to attend the meeting. The central controller may refer to meetings table 5100 (field 5128) to find the project to which a meeting relates. The central controller may recommend attendees who had attended other meetings related to Project X. The central controller may also refer to project personnel table 5800 to find and recommend employees associated with Project X.
The meeting owner, prior to setting up the meeting, could be required to identify one or more functional areas that will be critical to making the meeting a success, preferably tagging the meeting with those functional areas.
In various embodiments, the central controller 110 recommends meeting invites based on the ratings of the individuals to be invited (e.g., as indicated in Meeting Participation/Attendance/Ratings table 5500). For example, if this is an innovation meeting, the central controller can recommend participants that were given a high rating on innovation for the functional area they represent. In various embodiments, the central controller may find individuals or meeting owners with high engagement scores (e.g., as indicated in Meeting Engagement table 5300) involved in innovation, commitment, learning, or alignment meetings based on the relevant meeting tags (e.g., as indicated in Meetings table 5100, at field 5108).
In various embodiments, the central controller may find individuals named as inventors on patent applications and/or applications in different classifications, fields, technology areas that may be applicable to the meeting/project.
In various embodiments, the meeting owner in a meeting could request that the central controller 110 open up a video call with an employee who is going to be handed a baton as a result of the meeting discussions.
Cognitive Diversity
Having a diverse group of meeting participants can lead to better meeting outcomes, but it can be difficult to identify the right people to represent the right type of diversity. Employees can have a variety of backgrounds, experiences, personality types, and ways of thinking (cognitive types). These frameworks shape how individuals participate in meetings and interact with other members of the meeting. In various embodiments, the central controller 110 could improve meeting staffing by identifying employees' cognitive frameworks, suggesting appropriate mixes of these cognitive frameworks.
Identifying Cognitive Types
The central controller could identify employees' cognitive type through employee self-assessments, cognitive assessments or personality inventories (e.g., MMPI, “big 5,” or MBTI) conducted during hiring processes, or inductively through a learning algorithm of meeting data.
High Performance Meetings
Overtime, the central controller 110 could learn which combinations of cognitive types are likely to perform better together in different types of meetings. High performance meetings can be assessed by measurements such as post-meeting participant ratings, by meeting engagement data, or by meeting asset generation. For example, the central controller could learn over time that innovation meetings produce ideas when individuals with certain cognitive types are included in the meeting.
Suggesting Invitees to Create Diversity
The central controller 110 could flag meetings with hom*ogenous cognitive types and suggest additional meeting invitees to meeting owners to create cognitive diversity. Individual employees vary in their risk tolerance, numeracy, and other forms of cognitive biases. Meetings sometimes suffer from too many individuals of one type or not enough individuals of another type. The central controller can suggest to meeting owners that individuals be invited to a meeting to help balance cognitive types. For example, a decision-making meeting may include too few or too many risk tolerant employees. The central controller can prompt the meeting owner to increase or decrease risk aversion by inviting additional employees.
Optimization
At step 7912, the central controller 110 may optimize use of resources, according to some embodiments.
In order to maximize the business value from meetings, the central controller 110 can create optimal allocations of people, rooms, and technology in order to maximize Enterprise business value. The central controller could have information stored including the goals of the enterprise, a division, a team, or a particular initiative. For example, if two teams requested the same room for an afternoon meeting, the team working on a higher valued project could be allocated that room.
In various embodiments, the central controller can balance requests and preferences to optimize the allocation of meeting rooms and meeting participants/owners.
In various embodiments, the central controller could allocate meeting participants to particular meetings based on the skill set of the meeting participant.
In the case of a meeting participant being booked for multiple meetings at the same time, the central controller could provide the meeting participant with the meeting priority. For example, a subject matter expert is invited to three meetings at the same time. Based on the enterprise goals and priorities, the central controller could inform the subject matter expert which meeting is the highest priority for attendance.
In the case of multiple key meeting participants being asked to attend multiple meetings at the same time, the central controller 110 could optimize participants so all meetings are covered. For example, 5 subject matter experts are invited to 3 meetings taking place at the same time. The central controller could inform the subject matter experts which meeting they should attend so all meetings are covered.
At step 7915, the central controller 110 may send meeting invitations, according to some embodiments. Meeting invites may be sent to an employee's email address or to some other contact address of an employee (e.g., as stored in table 5000).
Automatic Meeting Scheduling
The central controller 110 could trigger the scheduling of a meeting, if a condition is met based upon data from an external source. The central controller could suggest meeting invitees relevant to the event. For example, an extreme event such as an increase in service tickets or a hurricane could trigger the scheduling of a meeting.
At step 7918, the central controller 110 may ensure proper pre-work/assets are generated (e.g., agenda), according to some embodiments.
Locking Functionality
In various embodiments, one or more privileges, access privileges, abilities, or the like may be withheld, blocked or otherwise made unavailable to an employee (e.g., a meeting owner; e.g., a meeting attendee). The blocking or withholding of a privilege may serve the purpose of encouraging some action or behavior on the part of the employee, after which the employee would regain the privilege. For example, a meeting organizer is locked out of a conference room until the meeting organizer provides a satisfactory agenda for the meeting. This may encourage the organizer to put more thought into the planning of his meeting.
In various embodiments, locking may entail: Locking access to the room; Preventing a meeting from showing up on your calendar; Video meeting software applications could be prevented from launching.
In various embodiments, locking may occur until a purpose is provided. In various embodiments, locking may occur until a decision is made. In various embodiments, locking may occur if the meeting contains confidential information and individuals without clearance are invited or in attendance. In various embodiments, locking may occur if the meeting tag (identifying strategy, feature, commitment, etc.) is no longer valid. For example, a tag of “Project X” might result in a lockout if that project has already been cancelled.
In various embodiments, locking may occur until the description of the asset generated is provided.
In various embodiments, locking may occur if the budget established by Finance for a project or overall meetings is exceeded.
In various embodiments, a meeting owner and/or participants could be provided with a code that unlocks something.
In various embodiments, different meeting locations can be locked down (prevented from use) based on environmental considerations such as outside temperature (e.g., too costly to cool a particular room during the summer, so don't let it be booked when temperature is too high) and/or all physical meeting rooms (or based on room size threshold) may be locked down based on communicable disease statistics such as season flu rate.
In various embodiments, during flu season, the central controller could direct a camera to determine the distances between meeting participants, and provide a warning (or end the meeting) if the distance was not conforming to social distancing protocols stored at the central controller.
At step 7921, the central controller 110 may remind a user of a meeting's impending start, according to some embodiments.
In various embodiments, a peripheral associated with a user may display information about an upcoming meeting. Such information may include: a time until meeting start; a meeting location; an expected travel time required to reach the meeting; weather to expect on the way to a meeting; something that must be brought to a meeting (e.g., a handout); something that should be brought to a meeting (e.g., an umbrella); or any other information about an upcoming meeting. In various embodiments, a peripheral may remind a user about an upcoming meeting in other ways, such as by providing an audio reminder, by vibrating, by changing its own functionality (e.g., a mouse pointer may temporarily move more slowly to remind a user that a meeting is coming up), or in any other fashion.
In various embodiments, the central controller may send a reminder to a user on a user's personal device (e.g., phone; e.g., watch). The central controller may text, send a voice message, or contact the user in any other fashion.
in various embodiments, the central controller may remind the user to perform some other task or errand on the way to the meeting, or on the way back from the meeting. For example, the central controller may remind the user to stop by Frank's office on the way to a meeting in order to get a quick update on Frank's project.
At step 7924, the central controller 110 may track users coming to the meeting, according to some embodiments.
On the Way to a Meeting
Meetings are often delayed when one or more participants do not reach the meeting room by the designated start time, and this can cause frustration.
Estimating Time of Arrival
The central controller 110 could estimate the time of arrival for participants from global positioning data and/or Bluetooth® location beacons and/or other forms of indoor positioning systems.
The central controller could display these times of arrival to the meeting owner.
Finding the Meeting
The central controller could provide meeting attendees with a building map indicating the location of the meeting room and walking directions to the room based upon Bluetooth® beacons or other indoor positioning systems. The central controller could also assist meeting participants in finding nearby bathroom locations or the locations of water fountains, vending machines, or coffee machines.
Late Important Participants
The central controller could prompt the meeting owner to delay the start of the meeting if key members of the meeting are running late.
Late Participants Messaging
Late participants could record a short video or text message that goes to the meeting owner. Exemplary messages may include: I'm getting coffee/tea now; I ran into someone in the hallway and will be delayed by five minutes; I will not be able to attend; I will now attend virtually instead of physically.
Catching Up Late Arrivals
The central controller 110 could send to late arrivals a transcript or portions of a presentation that they missed, via their phones, laptops, or other connected devices.
Pre-Meeting Evaluation
At step 7927, the central controller 110 may send out pre-meeting evaluation, according to some embodiments.
Meeting agendas and presentations are often planned far in advance of the meeting itself. Providing meeting owners with information collected from attendees in advance of the meeting allows meeting owners and presenters flexibility to tailor the meeting to changing circ*mstances.
Pre-Meeting Status Update
The central controller could elicit responses from attendees prior to the meeting by sending a poll or other form of text, asking how they feel prior to the meeting. Exemplary responses may include: Excited!; Dreading it; Apathetic; Sick; a choice from among emojis; and/or a choice of food and/or beverage.
At step 7930, the central controller 110 may set the room/meeting environment based on the evaluation, according to some embodiments.
Dynamic Response
Based upon these responses, the central controller can alter the physical environment of the room, order different food and beverage items, and alter the meeting owner about the status of attendees. The room can use this information, for example, to decide whether to: Request responses from participants; Order snacks/candy; Play more soothing music; Reduce/increase the number of slides; Change the scheduled duration of the meeting; Set chairs to massage mode; Turn the lights down/up; or to make any other decision.
Based on the type of meeting, agenda and the responses sent to the meeting organizer, the central controller 110 can provide coaching or performance tips to individual participants, via text or video or any other medium. For example, if there is an innovation meeting where the meeting participant is dreading the meeting, the central controller may text the individual to take deep breaths, think with an open mind, and not be judgmental. If there is a learning meeting where the meeting participant is excited, the central controller may advise the individual to use the opportunity to ask more questions for learning and share your energy.
In various embodiments, there may be attendee-specific rewards for attending, achieving and/or meeting goals. Rewards may be allocated/awarded by the meeting organizer and/or system.
At step 7933, the central controller 110 may start the meeting, according to some embodiments. Users may then join the meeting, according to some embodiments.
During the Meeting
Continuing with step 7933, the central controller manages the flow of the meeting, according to some embodiments.
Textual Feedback (Teleprompter)
In various embodiments, a presenter may receive feedback, such as from the central controller 110. Feedback may be provided before meeting (e.g., during a practice meeting), during a meeting, and/or after meeting
Presenters will sometimes use devices such as teleprompters to help them to remember the concepts that they are trying to get across. In various embodiments, a teleprompter may show textual feedback to a presenter. Feedback may specify, for example, if the presenter is speaking in a monotone, if the presenter is speaking too fast, if the presenter is not pausing, or any other feedback.
In various embodiments, a teleprompter may act in a “smart” fashion and adapt to the circ*mstances of a meeting. In various embodiments, some items are removed from the agenda if the meeting is running long. In various embodiments, the teleprompter provides speed/cadence queues.
In various embodiments, a presenter may receive feedback from a wearable device. For example, a presenter's watch may vibrate if the presenter is speaking too quickly.
Request an Extension
In various embodiments, a meeting owner or other attendee or other party may desire to extend the duration of a meeting. The requester may be asked to provide a reason for the extension. the requester may be provided with a list of possible reasons to select from.
In various embodiments, a VIP meeting owner gets precedence (e.g., gets access to a conference room, even if this would conflict with another meeting set to occur in that conference room).
In various embodiments, if a project is of high importance, the central controller may be more likely to grant the request.
In various embodiments, a request may be granted, but the meeting may be moved to another room. In various embodiments, a request may be granted, and the next meeting scheduled for the current room may be moved to another room.
Deadline and Timeline Indications
Companies often impose deadlines for actions taken to complete work. In the context of meetings, those deadlines can take a number of forms and can have a number of implications.
In various embodiments, there could be deadlines associated with actions for a particular meeting, like the need to get through an agenda by a certain time, or a goal of making three decisions before the end of the meeting. Based upon the meeting agenda, the central controller 110 can prompt the meeting owner if the current pace will result in the meeting failing to achieve its agenda items or achieve a particular objective If meeting participants do not achieve an objective in the time allotted, the central controller could:
-
- End the meeting
- End all instances of this meeting
- Move participants to a “lesser room”
- Shorten (or lengthen) the time allocated to the meeting
- Require the meeting owner to reapply for additional meeting time.
- Restrict the meeting owner from reapplying for additional time or from scheduling meetings without prior approval.
Room Engagement Biometric Measurements
At step 7936, the central controller 110 tracks engagement, according to some embodiments.
In various embodiments, one or more of the following signs, signals, or behaviors may be tracked: Eye tracking; Yawning; Screen time/distraction; Posture; Rolling eyes; Facial expression; Heart rate; Breathing Rate; Number of overlapping voices; Galvanic skin response; Sweat or metabolite response; Participation rates by individual.
In various embodiments, the central controller 110 may take one or more actions to encourage increased participation. For example, if Frank has not said anything, the central controller may ping him with a reminder or have him type an idea to be displayed to the room.
In various embodiments, there may be a range of “ping styles” based on the MBTI of a participant, based on such aspects of personality as introversion/extroversion levels, or based on other personality characteristics. In various embodiments, a participant may choose their preferred ping style.
In various embodiments, one or more devices or technologies may be used to track behaviors and/or to encourage behavioral modification.
In various embodiments, a mobile phone or wearable device (watch) is used for collection of biometric feedback during the meeting to the central controller and for meeting owner awareness. Real-time information to include; heart rate, breathing rate, and blood pressure. Analysis of data from all attendees alerts the meeting owner for appropriate action. This includes: tension (resulting from higher heart and breathing rates), boredom from lowering heart rates during the meeting and overall engagement with a combination of increased rates within limits.
In various embodiments, there exists wireless headphones with an accelerometer that detects head movement for communicating to the central controller and meeting owner. Downward movement includes boredom and lack of engagement. Nodding up and down can indicate voting/agreement by participants. Custom analytics of head movements based on attendee—e.g., cultural differences in head movements may be auto-translated into expressive chat text, status, metrics, etc.
In various embodiments, virtual meetings display meeting participants in the configuration of the room for a more true representation of being in the room. For example, if the meeting is taking place in a horseshoe room known by the central controller 110, the video of each person in each chair around the table should be displayed. This may provide advantages over conventional views where you get a single view of a table. This can create a more engaged virtual participant.
Various embodiments may include custom or even fanciful virtual room configurations and/or locations.
Individual Performance Indicators
At step 7939, the central controller 110 tracks contributions to a meeting, according to some embodiments.
In various embodiments, the central controller could measure the voice volume of individual speakers and/or speaking time to coach individuals via prompts (send a message to you to tone it down a bit or to let others speak). The central controller could analyze speech patterns to tell individuals whether they are lucid or coherent and inform speakers whether they are not quite as coherent as usual.
At step 7942, the central controller 110 manages room devices, according to some embodiments. This may include air conditioners, video players, projectors, and/or any other devices.
At step 7945, the central controller 110 alters a room to increase productivity, according to some embodiments. Alterations may include alterations to room ambiance, such as lighting, background music, aromas, images showing on screens, images projected on walls, etc. In various embodiments, alterations may include bringing something new into the room, such as refreshments, balloons, flowers, etc. In various embodiments, the central controller may make any other suitable alterations to a room.
Color Management
Color can be used for many purposes in improving meeting performance. Colors can be used to:
-
- Identify meeting type. For example, a learning meeting could be identified as green, an innovation meeting could be orange and a color allocated to any meeting.
- Highlight culture (e.g., to proudly display company colors; e.g., to show support for a group, a cause, a holiday, etc., represented by the color)
- The central controller could use various inputs to determine whether or not the participants are aligned, and then color the room green, for example, if there is good perceived alignment from these non-verbal signals:
- Arms crossed
- Eye rolling
- Nodding/Head shaking
- People leaning toward or away from other participants
- People getting out of their chairs
- People pushing themselves away from the table
- People pounding their fists on a table
- Reflect the mood/morale of people in the room
- Reflect the level of confusion
- Identify whether or not the meeting is off topic or on topic
- For example, when the meeting is going off topic the room controller could send a signal to lights in the room to cast a red light in the room as a reminder to participants that time may be being wasted.
- Indicate whether meeting participants are bored
Dynamic and Personalized Aroma Therapy
The central controller 110 can both detect and output smells to meeting participants as a way to better manage meetings. The central controller could be in communication with a diffuser that alters the smell of a room.
If a meeting participant brings food into the room, the central controller could detect the strength of the smell and send a signal to the meeting owner that they may want to remove the items because it could be a distraction.
When the central controller receives an indication that a meeting is getting more tense, it could release smells that are known to calm people—and even personalize those smells based on the participant by releasing smells from their chair or from a headset.
During innovation meetings, the central controller could release smells associated with particular memories or experiences to evoke particular emotions.
Food/Beverage Systems
Getting food delivered during a meeting can be a very tedious process. Tracking down the food selections of participants, getting order changes, tracking down people who never provided a food selection, or having to call in additional orders when unexpected participants are added to the meeting at the last minute.
Various embodiments provide for vendor selection. The central controller 110 can have a list of company approved food providers, such as a list of ten restaurants that are approved to deliver lunches. When a meeting owner sets up a meeting, they select one of these ten vendors to deliver lunch. The central Controller can track preferred food/drink vendors with menu selections along with preferences of each participant. If the meeting owner wants to have food, they select the vendor and food is pre-ordered.
Various embodiments provide for default menu item selections. The central controller 110 can have default menu selection items that are pre-loaded from the preferred food/beverage vendors. The administrator uploads and maintains the menu items that are made available to the meeting participants when food/beverages are being supplied. When participants accept an in-person meeting where food is served from an authorized vendor, the participant is presented with the available menu items for selection and this information saved by the central controller.
Various embodiments provide for participant menu preferences. The central controller maintains the menu preferences for each individual in the company for the approved food/beverage vendors. This can be based on previous orders from the vendor or pre-selected by each meeting participant or individual in the company. For example, a participant might indicate that their default order is the spinach salad with chicken from Restaurant “A”, but it is the grilled chicken sandwich with avocado for Restaurant “B”. In that way, any meeting which has identified the caterer as Restaurant “B” will create an order for the chicken sandwich with avocado for that participant unless the participant selects something else in advance.
Various embodiments provide for an ordering process. Once a meeting participant confirms attendance where food will be served, participants select their menu item or their default menu preference is used. The central controller aggregates the orders from all meeting attendees and places the order for delivery to the food vendor. Participant “A” confirms attendance to a meeting and is presented with the food vendor menu, they select an available option and the central controller saves the selection. Participant “B” confirms attendance to a meeting and is presented with the food vendor menu, but elects to use the default menu item previously saved. For those participants that did not select a menu item or have a previously saved preference for the vendor, the central controller will make an informed decision based on previous orders from other vendors. For example, always orders salads, is a vegetarian, or is lactose intolerant as examples. At the appropriate time, based on lead times of the food vendor, the central controller places the order with the food vendor.
Various embodiments provide for default meeting type food/beverage selections. The central controller 110 could store defaults for some meeting types. For example, any meeting designated as an Innovation Meeting might have a default order of coffee and a plate of chocolate to keep the energy high. For Learning meetings before 10 AM, the default might be fruit/bagels/coffee, while Alignment meetings after 3 PM might always get light sandwiches and chips/pretzels.
At step 7948, side conversations happen via peripherals or other devices, according to some embodiments.
In various embodiments, it may be desirable to allow side conversations to occur during a meeting, such as in technology-mediated fashion. With side conversations, employees may have the opportunity to clarify points of confusion, or take care of other urgent business without interrupting the meeting. In various embodiments, side conversations may be used to further the objectives of the meeting, such as to allow a subset of meeting participants to resolve a question that is holding up a meeting decision. In various embodiments, side conversations may allow an attendee to send words or symbols of encouragement to another attendee.
In various embodiments, side conversations may occur via messaging between peripherals (e.g., headsets, keyboards, mice) or other devices. For example, a first attendee may send a “thumbs up” emoji to a second attendee, where the emoji appears on the mouse of the second attendee. Where conversations happen non-verbally, such conversations may transpire without disturbing the main flow of the meeting, in various embodiments.
In various embodiments, the central controller 110 may create a whitelist of one or more people (e.g., of all people) in a meeting, and/or of one or more people in a particular breakout session. An employee's peripheral device may thereupon permit incoming messages from other peripheral devices belonging to the people on the whitelist. In various embodiments, the central controller 110 may permit communication between attendees’ devices during certain times (e.g., during a breakout session, e.g., during a meeting), and may prevent such communication at other times.
In various embodiments, the central controller may store the content of a side conversation. In various embodiments, if there are questions or points of confusion evident from a side conversation, the central controller may bring these points to the attention of the meeting owner, a presenter, or of any other party.
At step 7951, the central controller 110 manages breakout groups, according to some embodiments.
In various embodiments, a meeting may be divided into breakout groups. Breakout groups may allow more people to participate. Breakout groups may allow multiple questions or problems to be addressed in parallel. Breakout groups may allow people to get to know one another and a more close-knit environment. Breakout groups may serve any other purpose.
In various embodiments, the central controller 110 may determine breakout groups.
Breakout groups may be determined randomly, in a manner that brings together people who do not often speak to each other, in a manner that creates an optimal mix of expertise in each group, in a manner that creates an optimal mix of personality in each group, or in any other fashion. In various embodiments, breakout groups may be predefined.
In various embodiments, an employee's peripheral device, or any other device, may inform the employee as to which breakout group the employee has been assigned to. In various embodiments, a breakout group may be associated with a color, and an employee's peripheral device may assume or otherwise output the color in order to communicate to the employee his breakout group.
In various embodiments, a peripheral device may indicate to an employee how much time remains in the breakout session, and/or that the breakout session has ended.
In various embodiments, communications to employees during breakout sessions may occur in any fashion, such as via loudspeaker, in-room signage, text messaging, or via any other fashion.
Voting, Consensus and Decision Rules
At step 7954, decisions are made, according to some embodiments.
During meetings, participants often use rules, such as voting or consensus-taking, to make decisions, change the agenda of meetings, or end meetings. These processes are often conducted informally and are not recorded for review. The central controller could facilitate voting, gauging opinions, or forming a consensus.
The central controller 110 may allow the meeting owner to create a rule for decision making, such as majority vote, poll or consensus, and determining which meeting participants are allowed to vote.
The central controller may allow the votes of some participants to be weighted more/less heavily than others. This could reflect their seniority at the company, or a level of technical expertise, domain expertise, functional expertise, or a level of knowledge such as having decades of experience working at the company and understanding the underlying business at a deep level.
The central controller may share a poll with meeting participants.
The central controller may display the aggregated anonymized opinion of participants on decision or topic.
The central controller may display the individual opinion of participants on a decision or topic.
The central controller may require individuals to provide a rationale for a vote either through preconfigured answers or open-ended responses.
The central controller 110 may display a summary of rationales. For example, the central controller could identify through text analysis the top three factors that were cited by those voting in favor.
The central controller may use a decision rule to change, add or alter the agenda, purpose or deliverable of the meeting.
The central controller may facilitate voting to end the meeting or extend the time of the meeting.
The central controller may match meeting participants who share similar or dissimilar opinions on a topic for a breakout session.
The central controller may record votes and polls to allow review.
The central controller may determine over time which employees have a track record of success/accuracy in voting in polls or who votes for decisions that result in good outcomes through an artificial intelligence module.
The central controller may allow for dynamic decision rules which weights participants' votes based upon prior performance as determined by an artificial intelligence module.
The meeting owner could add a tag to a presentation slide which would trigger the central controller to initiate a voting protocol while that slide was presented to the meeting participants.
In various embodiments, votes are mediated by peripherals. Meeting attendees may vote on a decision using peripherals. For example, a screen on a mouse displays a question that is up for a vote. An attendee can then click the left mouse button to vote yes, and the right mouse button to vote no. Results and decisions may also be shown on peripherals. For example, after a user has cast her vote, the screen shows the number of attendees voting yes and the number of attendees voting no.
At step 7957, the central controller 110 tracks assets, according to some embodiments.
In various embodiments, the central controller 110 solicits, tracks, stores, and/or manages assets associated with meetings. Assets may be stored in a table such as table 6000.
The central controller may maintain a set of rules or logic detailing which assets are normally associated with which meetings and/or with which types of meetings. For example, a rule may specify that a list of ideas is one asset that is generated from an innovation meeting. Another rule may specify that a list of decisions is an asset of a decision meeting. Another rule may specify that a deck is an asset of a learning meeting.
If the central controller does not receive one or more assets expected from a meeting, then the central controller may solicit the assets from the meeting owner, from the meeting note taker come out from the meeting organizer, from imaging presenter, from a meeting attendee, or from any other party. The central controller may solicit such assets via email, text message, or via any other fashion.
In various embodiments, if the central controller does not receive one or more assets expected from a meeting (e.g., within a predetermined time after the end of the meeting; e.g., within a predetermined time of the start of the meeting; e.g., within a predetermined time before the meeting starts), then the central controller may take some action (e.g., enforcement action). In various embodiments, the central controller may revoke a privilege of a meeting owner or other responsible person. For example, the meeting owner may lose access to the most sought-after conference room. As another, the meeting owner may be denied access to the conference room for his own meeting until he provides the requested asset. As another example, the central controller may inform the supervisor of the meeting owner. Are there enforcement actions may be undertaken by the central controller, in various embodiments.
Rewards, Recognition, and Gamification
At step 7960, the central controller 110 oversees provisions of rewards and/or recognition, according to some embodiments.
While management can't always be in every meeting, various embodiments can provide ways for management to provide rewards and/or recognition to people or teams that have achieved certain levels of achievement.
In various embodiments, the following may be tracked: Participation rate in meetings; Engagement levels in meetings; Leading of meetings; Questions asked; Assets recorded; Ratings received from meeting owner or other participants; Post-meeting deliverables and/or deadlines (met or missed); Meeting notes typed up; Demonstrated engagement levels with meeting materials such as reading time or annotations; Tagging of presentation slides.
In various embodiments, reward/recognition may be provided in the form of:
-
- Promotions
- Role changes
- The central controller begins to identify those highly regarded in the organization for different meeting types. For example, a meeting owner who received good scores for running Innovation Meetings might be chosen to run more Innovation sessions, or to be a trainer of people running or attending Innovation meetings.
- Salary increase
- Central controller aggregates meeting participant scores and informs their manager when salary increases are taking place.
- Bonuses
- Meeting room/time slot preferences
- Top meeting owners/participants get preferred status for best rooms, meeting times, other assets
- Additional allocation of meeting ‘points’ (for scheduling/permitting meetings, etc.)
- Name displayed on room video screens
- A recipient's peripheral device changes its appearance. E.g., an employee's mouse glows purple as a sign of recognition. An employee's peripheral may change in any other fashion, such as by playing audio (e.g., by playing a melody, by beeping), by vibrating, or in any other fashion.
- Identify a person as one of the following:
- Top meeting owner
- Top participant
In various embodiments, certain stats may be tracked related to performance:
-
- Baseball card stats for meetings or people or rooms
- Perfect attendance or on time, or finish on time, or develop good assets, reach good decisions, feed good outputs, as inputs to next meeting AFTER THE MEETING
In various embodiments, the central controller 110 asks whether or not you attended the meeting.
In various embodiments, the central controller requests notes and vote(s) from you (and perhaps others), including ratings on the room and equipment itself and other configured items established by the meeting owner.
In various embodiments, the central controller provides your meeting engagement score (participant or owner) and leadership improvement data.
In various embodiments, the central controller 110 can identify people with higher engagement scores for coaching sessions.
In various embodiments, the central controller asks if the meeting should be posted for later viewing by others.
Sustainability
At step 7963, the central controller 110 scores a meeting on sustainability, according to some embodiments. Some contributions to sustainability may include: environmental soundness, reduced meeting handouts (physical), increased remote participation, etc.
Many companies are now working diligently to respect and preserve the environment via Corporate Social Responsibility (CSR) focus and goals. These CSR goals and initiatives are key in improving and maintaining a company's reputation, maintaining economic viability and ability to successfully recruit the next generation of knowledge workers. Various embodiments can help to do that. For example, companies may take the following thinking into consideration:
-
- Making virtual participation more effective allows for fewer participants having to travel for meetings, reducing car exhaust and airplane emissions.
- With smaller meetings, smaller meeting rooms can be chosen that require less air conditioning.
- Carbon dioxide elimination/Green score/Corporate Social Responsibility score by meeting and individual—participants that are remote and choose to use virtual meetings are given a CO2 elimination/green score.
- These scores can be broadcast throughout the company.
- These scores can be highlighted in corporate communications or on a company website.
- Not printing content and making all presentations, notes, feedback and follow-up available electronically, can generate a green score by participants/meeting/organization.
- Brainstorming sessions can be done regarding making environmental improvements, with the results of those sessions quickly made available to others throughout the enterprise, and the effectiveness of those suggestions tracked and evaluated.
- The company heating/cooling system could get data from the central controller in order to optimize temperatures.
- When engagement levels start to drop, experiment with changes in temperature to see what changes help to bring engagement levels up.
- When the central controller knows that a meeting room is not being used, the air conditioning can be turned off. It can also be turned back on just before the start of the next meeting in that room. At 3 PM if the last meeting is done, the AC should go off and the door should be closed.
- When the central controller knows a meeting participant is attending a meeting in person, the air conditioning or heating temperature should be adjusted in the attendee's office to reflect that they are not in their office.
- Room blinds should be controlled to minimize energy requirements.
Headsets equipped with temperature, environmental and light sensors, along with cameras and microphones, could collect data from each user in a meeting room. This data could be sent to the central controller and communication in the room controller to adjust the environmental elements or provide feedback for adjustments. The dynamic changes could help to conserve power and contribute to a positive CSR score.
CSR scores could be broadcast throughout the company's headsets for education and awareness purposes.
Headsets may facilitate heating/cooling adjustments. Headsets could collect the body temperature of each person. If the temperature increases beyond a particular threshold, the central controller could communicate with the in-room controller or central HVAC system to start the air conditioning. Likewise, if the body temperatures are too cold, the central controller could communicate with the in-room controller or central HVAC system to stop the air conditioning and possibly turn on the heat.
Headsets with cameras could detect the number of people in a meeting room. If the number of people in the room is significantly less than the accommodating size (e.g., 2 people sitting in a 20 person conference room), the HVAC system is not adjusted and conserves power. This could mimic the environmental control behavior of the central controller when a room is not in use and encourage the use of other rooms or virtual meetings.
Room blinds could be controlled to minimize energy requirements. If the headset senses light shining on a presentation panel or the room is becoming too hot, the in-room controller could obtain information from the central controller and close the blinds. Likewise, if the room becomes too dark on a sunny day, the in-room controller could obtain information from the central controller and automatically open the blinds letting in light, thus reducing the need to turn on lights.
In various embodiments, headsets may facilitate maintenance. With respect to office equipment and furniture, the headsets (cameras) could notice that chairs are missing from the room and notify the facilities department via the central controller that chairs are missing and could be brought to the conference room. This could occur for any missing asset that is not registered with the central controller for the associated room (e.g., trash cans, markers).
With respect to maintaining office cleanliness, the headsets (cameras) could notice that the trash can is full of lunch from a previous meeting or that there are crumbs on the floor and the cleaning crew could be dispatched to clean the room via the central controller. In addition, if the trash can is not full or the room is clean, the cleaning crew could be notified to not access the room and save on maintenance and power costs.
In various embodiments, the central controller 110 could have access to the organization's environmental Corporate Social Responsibility (CSR) goals and targets. These are preloaded into the central controller. When meetings are scheduled, the central controller informs the meeting lead and participant of the meetings CSR target score based on the overall organization goals. When team members elect to participate remotely or not print documents related to the meeting these are components that generate a CSR meeting score. This score can be maintained real-time by the central controller and used to monitor and update in real-time the CSR score to target goal. This score can be promoted on both internal sites for employee awareness and external sites for customer viewing. For example, meeting owner “A” schedules a meeting with 10 people in location ABC. 5 people are remote, 3 work from home and 2 are co-located in location ABC. The meeting owner is provided with the CSR target goal of 25%. If 3 of the 5 remote attendees elect to not fly to location or rent a car or stay in a hotel in location ABC, the meeting receives a positive contribution to the CSR goal. When 2 people decide to fly to the meeting, they receive a negative contribution to the CSR goal since they are contributing to more carbon dioxide emissions, renting fossil fuel vehicles and staying in hotels that use more energy. Likewise, the 3 people that work from home and do not drive to the office contribute positively to the CSR goal. The 2 co-located meeting participants in location ABC receive a score as well since they drive to the office daily and consume utilities at their place of employment. Furthermore, as attendees see the meeting CSR score in advance of the meeting and make alternative choices in travel and attendance, the score adjusts. As more people elect to attend in person, the score begins to deteriorate. If people begin to print copies of a presentation, the network printers communicate to the central controller and the CSR score begins to deteriorate as well. As more people attend in person, the AC/Heating costs begin to increase and again, this contributes negatively to the CSR score. Upon completion of the meeting, the final CSR score is provided to all attendees and the central controller maintains the ongoing analytics of all meetings for full reporting by the organization.
Even when meetings are not taking place in a physical room, the room itself could be contributing to a negative CSR score. Rooms require heat and cooling even when no one is in the workplace. The meeting controller should be aware of all meetings and proactively adjust the heating and cooling of each room. For example, the meeting controller knows a meeting is taking place in conference room “A” from 8:00 AM-9:00 AM. The meeting room controller should alert the heating and cooling system to adjust the temperature to 76 degrees Fahrenheit at 7:45 AM. Also, the meeting room controller should also notice that another meeting is taking place from 9:00 AM-10:00 AM in the same room and hence should maintain the temperature. If however, there is no meeting scheduled from 9:00 AM-11:00 AM, the central controller should inform the heating and cooling system to turn off the system until the next scheduled meeting. When temperatures are adjusted to match the use of the room, the CSR score is positively impacted since less energy is used.
Since the central controller 110 also knows which individuals are attending the meeting in person, if the individual has an office, the heating and cooling system should be adjusted in the office to conserve energy. For example, person “A”, who sits in an office, elects to attend a meeting in conference room “B” in person at 8:00 AM. At 7:55 AM, or whenever the time to travel begins for the individual, the central controller informs the heating and cooling system to adjust the temperature for an unoccupied room. In this case, it could be set to 80 degrees Fahrenheit. Since the office is not occupied during the meeting time, less energy is spent heating and cooling the office. This contributes positively to the overall CSR target score and the central controller maintains this information for use by the organization.
As temperature conditions in the room are impacted by sun through windows, the central controller should interface with the window blind system accordingly. For example, in the winter, the central controller could interface with the local weather system to determine that it will be sunny and 45 degrees Fahrenheit outside and that the room windows face the south. In this case, in order to use solar energy, the blinds of the meeting room should be opened by the central controller to provide heat and hence use less energy sources. Likewise, in the summer, with a temperature of 90 degrees Fahrenheit, this same southern facing conference room should have the blinds closed to conserve cooling energy. This data should be provided by the central controller to the overall CSR target goals for the organization. The central controller could integrate to sites to calculate the CSR savings/Green savings by not flying or driving. Since the central controller knows where the meeting participant is located and where the meeting is taking place they can determine the distance between the locations and calculate the savings. For example, the central controller knows the meeting is taking place at 50 Main Street in Memphis, Tennessee. An individual in Denver, Colorado elects to participate remotely and not travel. The central controller can access a third party site to calculate the CO2 emissions saved thus the positive contribution to the CSR target. In addition, a person in a suburb of Memphis decides to participate remotely and not drive to the meeting. The central controller can access third party mapping software and determine the driving distance and access a third party site to calculate the CO2 emission saved. This information is collected by the central controller and provided to the organization for CSR reporting.
Keyboards
Turning now to
Headset device 8000 may include various components. Headset device 8000 may include a processor 8005, network port 8010, connector 8015, input device 8020, output device 8025, sensor 8030, screen 8035, power source 8040, storage device 8045, AI accelerator 8060, cryptographic accelerator 8065, and GPU (graphics processing unit) 8070. Storage device 8045 may store data 8050 and program 8055. A number of components for headset device 8000 depicted in
In various embodiments, analogous components in different devices (and/or in different variations of a device) may use a similar and/or analogous numbering scheme. For example, reference numerals for like components may differ only in the “hundreds” or “thousands” digits, but may have similar trailing digits. For example, processor 305 in
In various embodiments, connector 8015 may include any component capable of interfacing with a connection port (e.g., with connection port 315). For example, connector 8015 may physically complement connection port 315. Thus, for example, headset device 8000 may be physically connected to a user device via the connector 8015 fitting into the connection port 315 of the user device. The interfacing may occur via plugging, latching, magnetic coupling, or via any other mechanism. In various embodiments, a headset device may have a connection port while a user device has a connector. Various embodiments contemplate that a user device and a headset device may interface with one another via any suitable mechanism. In various embodiments, a user device and a headset device may interface via a wireless connection (e.g., via Bluetooth®, Wi-Fi®, or via any other means).
AI accelerator 8060 may include any component or device used to accelerate AI applications and calculations. AI accelerator 8060 may use data collected by sensor 8030 and/or input device 8020 to use as input into various AI algorithms to learn and predict outcomes. AI accelerator 8060 may use storage device 8045 for both input and result data used in AI algorithms and calculations.
In various embodiments, AI accelerator 8060 can send a signal back to user device 106a upon making a prediction, determination, or suggestion. For example, if a user is playing a game and it is determined by AI accelerator 8060 that the user is performing poorly a signal can be sent back to user device 106a to adjust the difficulty to a more appropriate level. It may also track a user's learning curve and be able to predict when the user will require a harder level.
In various embodiments, AI accelerator 8060 can use multifaceted data collected by sensor 8030 as input to induce actions. The AI accelerator can use this information, for example, to: trigger recording of the current game session when a user shows excitement through speech or skin response, induce a vibration in the headset if the user is showing signs of being distracted or sleepy, etc.
In various embodiments, AI accelerator 8060 may combine data from various sources including sensor 8030 and input device 8020 with its own data calculated and/or stored on storage device 8045 over a long period of time to learn behaviors, tendencies, idiosyncrasies and use them for various purposes. For example, the AI accelerator may determine that the person using headset 8000 currently is not the approved user based on movement patterns, ambient sound, voiceprint, fingerprint, etc. and prevent unauthorized access of headset 8000. The AI accelerator may find concerning medical conditions through heart rate sensor, temperature, movement patterns and notify the user to seek medical attention. The accelerator may determine the user's learning capabilities and knowledge base to determine complexity settings on future games, applications, templates, etc.
Cryptographic accelerator 8065 may include any component or device used to perform cryptographic operations. Cryptographic accelerator 8065 may use data collected by various sources including but not limited to sensor 8030 and/or input device 8020 to use as input into various cryptographic algorithms to verify user identity, as a seed for encryption, or to gather data necessary for decryption. Cryptographic accelerator 8065 may use storage device 8045 for both input and result data used in cryptographic algorithms.
In various embodiments, cryptographic accelerator 8065 will encrypt data to ensure privacy and security. The data stored in storage device 8055 may be encrypted before being written to the device so that the data can only be usable if passed back through 8065 on output. For example, a user may want to store sensitive information on the storage device on headset 8000 so that they can easily authenticate themselves to any attached user device 106a. Using the cryptographic accelerator to encrypt the data ensures that only the given user can decrypt and use that data. In some embodiments, cryptographic accelerator 8065 includes multifactor authentication capability so that headset 8000 may be used in remote authentication protocols.
In various embodiments, cryptographic accelerator 8065 will encrypt signals to ensure privacy and security. Signals sent to user device 106a through connector 8015 and connection port 315 can be encrypted so that only a paired user device can understand the signals. Signals may also be encrypted by the cryptographic accelerator and sent directly via network port 8010 to another peripheral device 107a via that device's network port 410. For example, a user may use a microphone on their headset to record speech for private communications and that data can pass through cryptographic accelerator 8065 and be encrypted before being transmitted. The destination device can decrypt using its cryptographic accelerator using shared keys ensuring no other party could listen in.
GPU (graphics processing unit) 8070 may include any component or device used to manipulate and alter memory to accelerate the creation of images in a frame buffer intended for output on one or more display devices. GPU 8070 may use data collected by various sources including but not limited to sensor 8030 or from the attached user device via connector 8015 to use in graphics processing. GPU 8070 may use storage device 8045 for reading and writing image data.
In various embodiments, GPU 8070 will create image data that will be displayed on screen 8035 or output device 8025. For example, a user is playing a game and GPU 8070 can be used to process data and display the data on a keyboard display (output device 8025), and can assist in processing graphics data.
In some embodiments, headset device 8000 includes controller 8075 which can manage multiple devices 8080 in order to reduce the computational load on processor 8005.
In some embodiments, storage device 8045 may store financial data (e.g., credit card numbers, bank account numbers, passwords, digital currencies, coupons), medical data, work performance data, media (e.g., movies, songs, books, audio books, photos, instruction manuals, educational materials, training materials, presentations, art, software applications, advertisem*nts), etc. In various embodiments, users may be required to authenticate themselves to headset 8000 before gaining access to data stored in storage device 8045.
With reference to
With reference to
Keyboard Output Examples
In various embodiments, a keyboard is used to output information to a user. The keyboard could contain its own internal processor. Output from the keyboard could take many forms.
In various embodiments, the height of keys serves as an output. The height of individual keys (depressed, neutral or raised) could be controlled as an output.
In various embodiments, a keyboard contains a digital display screen. This could be a small rectangular area on the surface of the keyboard which does not interfere with the activity of the user's fingers while using the keyboard. This display area could be black and white or color, and would be able to display images or text to the player. This display would receive signals from the user device or alternately from the central controller, or even directly from other peripheral devices.
In various embodiments, the screen could be touch-enabled so that the user could select from elements displayed on this digital display screen. The screen could be capable of scrolling text or images, enabling a user to see (and pick from) a list of inventory items, for example. The screen could be mounted so that it could be flipped up by the user, allowing for a different angle of viewing. The keyboard display could also be detachable but still controllable by software and processors within the mouse.
In various embodiments, a keyboard may include lights. Small lights could be incorporated into the keyboard or its keys, allowing for basic functionality like alerting a user that a friend was currently playing a game. A series of lights could be used to indicate the number of wins that a player has achieved in a row. Simple lights could function as a relatively low-cost communication device. These lights could be incorporated into any surface of the keyboard, including the bottom of the keyboard. In some embodiments, lights are placed within the keyboard and can be visible through a semi-opaque layer such as thin plastic. The lights could be directed to flash as a way to get the attention of a user.
In various embodiments, a keyboard may render output in the form of colors. Colors may be available for display or configuration by the user. The display of colors could be on the screen, keys, keyboard, adjusted by the trackball or scroll wheel (e.g., of a connected mouse; e.g., of the keyboard), or varied by the sensory information collected. The intensity of lights and colors may also be modified by the inputs and other available outputs (games, sensory data or other player connected devices).
In various embodiments, a keyboard may render outputs in the form of motion. This could be motion of the keyboard moving forwards, backwards, tilting, vibrating, pulsating, or otherwise moving. Movements may be driven by games, other players or actions created by the user. Motion may also be delivered in the form of forces against the hand, fingers or wrist. The keyboard device and keys could become more firm or softer based on the input from other users, games, applications, or from the keyboard's own user. The sensitivity of the keys could adjust dynamically.
In various embodiments, a keyboard may render outputs in the form of sound. The keyboard could include a speaker utilizing a diaphragm, non-diaphragm, or digital speaker. The speaker could be capable of producing telephony tones, ping tones, voice, music, ultrasonic, or other audio type. The speaker enclosure could be located in the body or bezel of the keyboard.
In various embodiments, a keyboard may render outputs in the form of temperature (or temperature changes). There could be a small area on the surface of the keyboard keys or in the keyboard bezel which contains heating or cooling elements. These elements could be electrical, infrared lights, or other heating and cooling technology. These elements could output a steady temperature, pulsating, or increase or decrease in patterns.
In various embodiments, a keyboard may render outputs in the form of transcutaneous electrical nerve stimulation (TENs). The keyboard could contain electrodes for transcutaneous electrical nerve stimulation. These electrodes could be located in the keys or the areas corresponding with areas used by fingertips or by the palm of the hand. These electrodes could also be located in an ergonomic device such as a wrist rest.
In various embodiments, a keyboard may render outputs in the form of scents, smells, or odors. A keyboard may include a scent machine (odor wicking or scent diffuser). The keyboard could contain an air scent machine, either a scent wicking device or a scent diffusing device. This air scent machine could be located in the body or bezel of the keyboard.
Referring to
Game character ID field 8702 may include an identifier (e.g., a unique identifier) for a particular game character. In some embodiments, a game character can be an object such as a car or boat, or a collection of game protocols that may be separated into two or more pieces such as poker actions and bet sizing. Independently controllable elements field 8704 may include an identification of two or more elements (e.g., aim, trigger pulls, and movement) for a particular game character ID 8702. In some embodiments, each element is controlled by a single player, with the player's peripheral device providing input for the independently controllable element selected or assigned to the player. Each of these three input streams is assembled by central controller 110 so that the game character has all controllable elements in place to control the game character. In various embodiments, one or more players may be assigned (or choose) to provide input for two or more of the independently controllable elements. Time of control field 8706 may store the length of the game play session in which independently controllable elements are controlled by players. In some embodiments, this is a fixed amount of time like ‘5 minutes’, though triggers (e.g., ‘until game ends’, ‘duration of tournament’) could also serve as an end point for the play session.
Referring to
Peripheral ID field 8802 may include an identifier (e.g., a unique identifier) for a particular peripheral device of a user. User ID normally in control field 8804 may include an identifier (e.g., a unique identifier) for a particular user who is normally in control of peripheral 8802. In some embodiments, this may be the owner of the peripheral device 8802, or the current user holding peripheral device 8802. User ID taking over control field 8806 may include an identifier (e.g., a unique identifier) for a particular user who is taking over control of peripheral 8802. In some embodiments, this may be an opponent of the user normally in control 8804, or a teammate of the user normally in control. End time of user taking over control field 8808 may store the date and time at which control of the peripheral reverts back to the user ID normally in control of the peripheral. In other embodiments, control may revert back upon a game result (e.g., the user taking control loses a battle), a payment by the user normally in control (e.g., points, digital currency, money), the end of a game session, etc.
With reference to
Headset 9000 includes a camera 9090 attached to a bendable stalk 9080 which attaches camera 9090 to housing 9008. In various embodiments, bendable stalk 9080 allows a user to position camera 9080 to capture video or still images from many angles. In some embodiments, bendable stalk 9080 may be made from a material that is capable of bending, though it retains its position once bent. In various embodiments, camera 9090 may be aimed at an object in front of the user, aimed at another user, aimed at the user's face (e.g., to capture distances between eyes, ears, nose and mouth for biometric calculations), aimed at one of the user's eyes (e.g., to capture an image of the user's iris for a biometric calculation), aimed at the user's lips (e.g., to capture lip movements to help other user's understand what the user is saying), aimed at a tattoo of the user (e.g., to transmit a photo of the tattoo to central controller 110 to aid in identifying or authenticating the user), aimed at clothing or jewelry of the user, aimed at the hair of the user, aimed at the skin of the user's neck (e.g., to determine an approximate age of the user), aimed at written text, aimed at tools required to fix an object (e.g., copy machine), aimed at a pet (e.g., to aid in identifying or authenticating the user), aimed at the user's clothing, aimed at an aspect of the environment around the user which identifies the user's current location (e.g., street signs, a name plaque on a building, a recognizable building facade), etc. In some embodiments, lights 9042a, 9042b, 9044, and/or 9026 may be illuminated by headset 9000 in order to provide better lighting conditions for camera 9090. In some embodiments, camera 9090 includes one or more lights that may be directed at the object camera 9090 is pointed at. In some embodiments, headset 9000 includes microphone 9095.
In some embodiments, bendable stalk 9080 includes one or more motors which are under control of central controller 110 so that central controller 110 may “look around” the user. Such motors may also enable headset 9000 to maintain a video feed associated with a fixed object in the field of view even when the user turns her head.
In other embodiments, video captured by camera 9090 may be output via display screen 9046 and/or projector 9076, allowing the user to see what camera 9090 is pointed at. In some embodiments, headset 9000 uses data from accelerometers 9070a and 9070b in order to determine the position of the user's head, and uses that head position to better identify where the user is looking.
In various embodiments, headset 9000 may facilitate observing a path for safety where a user is walking, running, or biking. Active users oftentimes walk, run or bike in areas where paths are worn or items are obstructing the path, causing potential safety hazards through tripping and falling. Headset 9000 with camera 9090 on a bendable stalk 9080 may assist the user. A biker may be riding on a path that has broken asphalt and potholes. Camera 9090 with the bendable stalk 9080 may be adjusted by the biker to focus slightly forward and downward on the path, allowing the biker to observe and pay attention to other surroundings (e.g., walkers, scenery, animals). While the biker is observing a walker with a dog coming in his direction, camera 9090 may detect a pothole on the path. The headset may notify the biker through the speaker (e.g., buzz) alerting him that a pothole or object is approaching and to stay alert. Likewise, display 9046 may show the pothole to provide a more clear indication of the object in front of the biker.
In various embodiments, headset 9000 may watch children while a user is working.
There may be times where a parent needs an extra set of eyes to watch children while working. While on conference call, a remote home worker may wear headset 9000 with camera 9090. A baby is sitting in a seat next to the parent and the parent focuses camera 9090 with the bendable stalk 9080 on the baby. While the parent is watching a computer monitor on a conference call and working, camera 9090 may be focused on the baby. During the conference call, the camera detects the baby waking and moving, signifying to the parent that they are wanting attention. Display 9046 alerts the parent to take a break and address the baby's needs by showing a video of the baby. Likewise, boom lights 9044 may blink yellow to indicate that the parent needs to tend to the baby.
In various embodiments, headset 9000 may facilitate the fixing of something while observing another function. There are times when a user needs to focus on one task but observe the effects of their actions. For example, an exterior light on a home has stopped working and the homeowner suspects a blown fuse that needs reset. Wearing headset 9000, the homeowner may open the electrical panel and point camera 9090 with bendable stalk 9080 towards the exterior light that is not working. Lights 9042a-b may illuminate the electrical panel so the homeowner can see the panel switches. While resetting each electrical switch, camera 9090 may detect when the exterior light comes back on. As the light turns on, a message may be heard by the homeowner in the speaker (e.g., ‘fixed’) or display 9046 may show the video of the light coming on collected by camera 9090. These alerts may allow the homeowner to stay focused on resetting the electrical panel while being informed of the task completion using the camera 9090 on bendable stalk 9080.
In various embodiments, headset 9000 may facilitate lip reading from a distance.
Individuals with hearing impairments rely on lip reading, but this requires the individual to be in close proximity to the person speaking in order to see their lips. Headset 9000 with camera 9090 may help provide a closer image of a person's lips to aid in lip reading. In some embodiments, a user with headset 9000 may attend a conference and attempt to listen to a keynote speaker on stage and take notes. The user may adjust camera 9090 with bendable stalk 9080 toward the stage, focusing on the keynote speaker's lips. The keynote speaker's lips may be magnified and projected on display 9046, allowing a clearer view and ability for the user to read the lips. This feature provides enhanced opportunities for hearing impaired individuals.
In various embodiments, headset 9000 may assist in gathering health assessments.
Health assessments of individuals entering the country are oftentimes random. In some embodiments, temperature checks for international travelers at arriving airports are random. An airport worker with headset 9000 and camera 9090 on a bendable stalk 9080, may point the camera to the arriving passenger passageway. As passengers enter, the camera 9090 with a thermal sensor may detect the temperature of each person. If a passenger has an elevated temperature, projector 9076 may display the image of the person and a message on a wall for them to step to the side for evaluation, an image of the person may show on display 9046 prompting the attendant to approach the passenger or a sound may be played in the speaker to alert the attendant of needed action (e.g., detain passenger). Likewise, as in various embodiments, camera 9090 may detect other passenger biometric data to validate against no-fly lists and potential threats.
In various embodiments, headset 9000 may assist a user in recalling names and details. It is common for people to forget names and details of individuals, especially if their interactions are limited. Headset 9090 may assist users in this situation. In some embodiments, a salesperson may have met a person and had a brief conversation at a conference. The salesperson with camera 9090 may collect this conversation and images of the person they are interacting with and store them in the data storage 9057 within housing 9008. Months later, at a different conference, the same individual approaches the salesperson. Camera 9090 on the bendable stalk 9080 is pointed to the crowd and recognizes the person from data storage 9057 in headset 9000. The camera display 9046 may provide the image, video or text of the earlier conversation to assist the salesperson in recalling specifics. Likewise, the speakers in headset 9000 may also provide the name of the approaching individual and any stored details. As the user approaches, the salesperson is equipped with information to re-engage the individual and not create an awkward moment of re-introductions.
In various embodiments, headset 9000 may facilitate checklists and checklist completion for technicians. Checklists are provided for many professionals as reminders to complete tasks and provide repetitive service.
With reference to
Headset 9100 includes a directional microphone 9190 attached to a bendable stalk 9180 which attaches directional microphone 9190 to housing 9108. In various embodiments, bendable stalk 9180 allows a user to position microphone 9180 to capture audio from different positions. In some embodiments, bendable stalk 9180 may be made from a material that is capable of bending, though it retains its position once bent. In various embodiments, directional microphone 9190 may be moved toward or away from the user's mouth. In some embodiments, detachable microphone 9190 and bendable stalk may be removed from headset 9100 and attached to another person or object.
In some embodiments, bendable stalk 9180 includes one or more motors which are under control of central controller 110 so that central controller 110 may move the directional microphone 9190 in the direction of an object of interest, such as another user.
In other embodiments, audio captured by directional microphone 9190 may be output via speaker 9174, allowing other nearby users to hear what microphone 9180 is picking up. In some embodiments, headset 9100 uses data from accelerometers 9170a and 9170b in order to determine the position of the user's head, and uses that head position to better identify where the user is looking.
In some embodiments, headset 9100 may facilitate including a user without a headset in a conversation. There may be situations where a user of a headset 9100 needs to share a microphone with a different user. In some embodiments, a manager is engaged in a conversation with a support person regarding a computer system outage using headset 9100 and microphone 9195. A developer enters the manager's office to engage in the conversation but does not have a headset. The manager points the directional microphone 9190 on bendable stalk 9180 to the developer to engage in the conversation. When the bendable stalk is pointed to the developer, the speaker 9174 begins to project the conversation so the developer can hear as well. Likewise, the manager may engage button 9130 to activate the speaker 9174 or directional microphone 9190 allowing another person to engage in the conversation.
In some embodiments, headset 9100 may facilitate listening in on background conversations as a casual listener. There may be a need to listen to other conversations in the background to provide input. People often do this naturally, or multi-task, but it distracts from the primary conversation they are engaged in. In some embodiments, headset 9100 can act as a second set of ears to listen and assist the user in responding. In some embodiments, a user is participating on a virtual conference call to address an emergency computer outage using headset 9100 and microphone 9195. At the same time, during a meeting in a physical room, the user is expected to participate when asked a question by those physically present in the room. At the beginning of the physical meeting the user points directional microphone 9190 on bendable stalk 9180 toward the other attendees in the conference room. When directional microphone 9190 receives the name of the user being spoken or keywords that were stored in a storage device on camera 9100, the headset alerts the user to participate. This alert may be in the form of a tone in the headset speaker (e.g., beep), displayed on the headset (e.g., you are needed) or by bringing the volume down on the emergency call. This adjustment in volume and alerts allows a user to participate in a primary conversation but be alerted to switch to a different conversation when notified. Likewise, when the particular conversation in the conference room ends, the user can select a button to return the volume to the initial level for the emergency call addressing the computer outage.
In some embodiments, headset 9100 may facilitate detecting key words, names or phrases to automatically amplify volume or provide an audible alert. Oftentimes users participate in conversations but are not actively engaged for a variety of reasons (e.g., lack of interest, not relevant at the moment, distracted with other tasks). Headset 9100 may amplify the volume in speaker 9110 when a user needs to engage. In various embodiments, at the end of a meeting, a user with a headset 9100 may be in a room with others discussing dates and times for the next meeting. The user happens to be taking notes, reading email or texts or planning their next day's activities and not paying attention. The directional microphone 9190 with bendable stalk 9180 may be pointed toward individuals in the physical room to follow the conversation, allowing the user to focus on other tasks. As the directional microphone 9190 receives the person's name being spoken or keyword (e.g., calendar, schedule, time) mentioned, as previously saved in data storage 9157, the speaker volume may automatically amplify or play a beeping sound, prompting the user to pay more close attention to the conversation.
In various embodiments, headset 9100 may assist people with hearing impairments.
Oftentimes people with hearing impairments need users to speak louder, but this can be frustrating to continually ask people. Directional microphone 9190 with bendable stalk 9180 may point to the person or room with individuals to pick up the conversations and amplify them in the headphone speaker 9110. In addition, accelerometer 9170-a-b may detect motion and direction of the head and directional microphone 9190 hone in on the person speaking, providing more clarity for the hearing impaired person.
In various embodiments, headset 9100 may detect a nearby speaker and project their voice to the audience in a conference call. There are times when a speaker in a physical conference room cannot be heard. The headset 9100 may be used to project their voice to the audience. For example, user 1 with a headset is in a physical conference room with many people. User 2 is sitting next to user 1 in the conference room but has forgotten to bring their headset. As user 2 is speaking, others on the conference call or in the physical conference room may begin to complain that they cannot hear user 2's comments and ask them to speak up. User 1, with headset 9100, points microphone 9190 on bendable stalk 9180 to user 2 sitting next to them. The headset and directional microphone may begin to detect and amplify the voice of user 2 to others on the conference call and in the physical conference room through the speakers in the room.
In various embodiments, headset 9100 may facilitate detection of sounds (e.g., kids playing, vehicles in proximity, people/things approaching) requiring a user response. There are embodiments where non-verbal sounds around a user need to be monitored for a response. For example, a jogger with a headset 9100 and directional microphone 9190 on bendable stalk 9180 may be jogging in the park on a dark path. A different jogger with a dog approaches them from behind.
Directional microphone 9190 is pointed behind the user and may detect the dog and jogger approaching. The display 9146 may indicate an approaching person through text, speaker 9110 may provide an alert (e.g., ‘caution, object approaching’ or beep) or boom lights 9144 may turn yellow indicating someone is approaching from behind. These indicators may provide the user with a sense of increased safety and help them not to be startled when someone approaches from behind.
In various embodiments, headset 9100 may include one or more electrodes (e.g., two electrodes 9197 and 9198). These may be conductors and may be fashioned from metal or some other conducting material. Electrodes may help to detect electrical potentials at different points on a user's head, and may thereby allow detection of brainwaves (e.g., EEG signals).
Turning now to
In various embodiments, a message is sent from the first peripheral device 9304 to the second peripheral device 9308. For example, the message may be a congratulatory message being sent from the owner of peripheral device 9304 to the owner of peripheral device 9308. The message may have any other form or purpose, and various embodiments.
The message originating from peripheral device 9304 may be transmitted via user device 9302, network 9310, and user device 9306 before reaching peripheral device 9308. At peripheral device 9308, the message may be output to a user in some fashion (e.g., a text message may be displayed on a screen of peripheral device 9308; e.g., an audible message may be broadcast from a speaker of a headset). In various embodiments, the message originating from peripheral device 9304 may be transmitted via network 9310, and via user device 9306 before reaching peripheral device 9308. In various embodiments, the message originating from peripheral device 9304 may be transmitted directly to peripheral device 9308 (e.g., if peripheral device 9304 and peripheral device 9308 are in direct communication).
In various embodiments, as a message is conveyed, the form of the message may change at different points along its trajectory. The message may be represented in different ways, using different technologies, using different compression algorithms, using different coding mechanisms, using different levels of encryption, etc. For example, when originally created, the message may have the form of electrical impulses read from a mouse button (e.g., impulses representing the pressing of the button). However, within the peripheral device 9304, the electrical impulses may be interpreted as discrete bits, and these bits, in turn, interpreted as alphanumeric messages. Later, when the message is transmitted from the user device 9302 to the network, the messages may be modulated into an electromagnetic wave and transmitted wirelessly.
Various embodiments include one or more modules (e.g., software modules) within devices 9304, 9302, 9306, and 9308. In various embodiments, such modules may contribute to the operation of the respective devices. In various embodiments, such modules may also interpret, encode, decode, or otherwise transform a message. The message may then be passed along to another module.
Modules may include programs (e.g., program 9455), logic, computer instructions, bit-code, or the like that may be stored in memory (e.g., in storage device 9445) and executed by a device component (e.g., by processor 9405). Separate modules may represent separate programs that can be run more or less independently of one another and/or with some well-defined interface (e.g., API) between the programs.
Operating system 9326 may be a module that is capable of interfacing with other modules and/or with hardware on the peripheral device 9304. Thus, in various embodiments, operating system 9326 may serve as a bridge through which a first module may communicate with a second module. Further, operating system 9326 may coordinate the operation of other modules (e.g., by allocating time slices to other modules on a processor, such as processor 9405). Further, operating system 9326 may provide and/or coordinate access to common resources used by various modules. For example, operating system 9326 may coordinate access to memory (e.g., random access memory) shared by other modules. Exemplary operating systems may include Embedded Linux™, Windows® Mobile Operating System, RTLinux™, Windows® CE, FreeRTOS, etc.
Component driver 9312 may serve as an interface between the operating system and an individual hardware component. As depicted, peripheral device 9304 includes one component driver 9312, but various embodiments contemplate that there may be multiple component drivers (e.g., one component driver for each component of the device). A component driver may translate higher level instructions provided by the operating system 9326 into lower-level instructions that can be understood by hardware components (e.g., into instructions that specify hardware addresses, pin numbers on chips, voltage levels for each pin, etc.). A component driver may also translate low level signals provided by the component driver into higher level signals or instructions understandable to the operating system.
Frame buffer 9314 may store a bitmap that drives a display (e.g., screen 9435). When another module (e.g., application 9318) wishes to output an image to a user, the module may generate a bitmap representative of the image. The bitmap may then be transmitted to the frame buffer (e.g., via the operating system 9326). The corresponding image may then appear on the display. If another module (e.g., application 9318) wishes to output a video to a user, the module may generate a sequence of bitmaps representative of sequential frames of the video. These may then be transmitted to the frame buffer for display one after the other. In various embodiments, the frame buffer may be capable of storing multiple images at once (e.g., multiple frames of a video), and may thereby ensure that video playback is smooth even if there are irregularities in transmitting the video bitmaps to the frame buffer.
User input/output controller 9316 may serve as an interface between the operation system 9326 and various input and output devices on the peripheral. As depicted, peripheral device 9304 includes one user input/output controller 9316, but various embodiments contemplate that there may be multiple user input/output controllers (e.g., one controller for each input device and output device on the peripheral). A user input/output controller provides an interface that allows other modules (e.g., application 9318) to retrieve data or messages from an input device (e.g., the left button was clicked). The user input/output controller also provides an interface that allows other modules (e.g., application 9318) to send data or commands to an output device (e.g., vibrate the peripheral). The data or messages sent via this controller may be modified so as to translate module level data and commands into ones compatible with the input and output devices.
Application 9318 may be any computer code run in the operating system 9326 that runs algorithms, processes data, communicates with various components, and/or sends messages. As depicted, peripheral device 9304 includes one application 9318, but various embodiments contemplate that there may be multiple applications (e.g., one application to send messages to peripheral device 9308 and another that plays a video on screen 9435). Applications may be run independently but may share resources (e.g., two applications running may both use database 9322 to read and store data).
AI Module 9320 may process various data input sources (e.g., input device 9420) to learn and predict user behavior. The AI Module may apply various heuristics and algorithms to parse the input data to construct and update models that can predict future input (e.g., predict when the next mouse click will come) or prepare a custom output (e.g., Display a congratulatory message on screen 9435 when a user completes a new level in a game). The module may use database 9322 to read saved models, create new models, and update existing ones that are stored on storage device 9445.
Database 9322 may serve as an interface to structured data on storage device 9445.
The database module provides an abstraction to other modules to allow high level read and write requests for data without knowledge of how the data is formatted on disk. As depicted, Peripheral device 9304 includes one database 9322, but various embodiments contemplate that there may be multiple databases (e.g., one storing click history and another an AI model). The database may store data in any format (e.g., relational database) and may be stored in multiple files and locations on storage device 9445. A database may also access remote data, either on user device 9302 or in the cloud via network 9310. The database may restrict access to data to certain modules or users and not allow unauthorized access.
Computer data interface controller 9324 may serve as an interface between the peripheral 9304 and the attached user device 9302 or peripheral device 9308. The interface controller allows messages and data packets to be sent in both directions. When another module (e.g., application 9318) wishes to send a message to a remote device, the module would use the API provided by the computer data interface controller 9324 to do so. The interface controller collects messages and data packets received by the peripheral and transmits them via operating system 9326 to the module that made the request or that is necessary to process them.
User device 9302 may include one or more modules, e.g., operating system 9340, computer data interface controller 9328, peripheral device driver 9330, application 9333, AI module 9334, database 9336, and network interface controller 9338. In various embodiments, user device 9302 may contain more or fewer modules, and may contain more or fewer instances of a given module (e.g., the user device may contain multiple application modules).
Operating system 9340 may have an analogous function on user device 9302 as does operating system 9326 on peripheral device 9304. Exemplary operating systems include Apple® macOS, Microsoft® Windows™, and Linux™
Computer data interface controller 9328 may serve as an interface between the user device 9302 and the peripheral device 9304. Computer data interface controller 9328 may have an analogous function to computer data interface controller 9324 in the peripheral device 9304.
Peripheral device driver 9330 may translate unique or proprietary signals from the peripheral device 9304 into standard commands or instructions understood by the operating system 9340. The peripheral device driver may also store a current state of the peripheral device (e.g., a mouse position). Peripheral states or instructions may be passed to operating system 9340 as needed, e.g., to direct progress in application 9332.
In various embodiments, peripheral device driver 9330 may translate messages from an application or other module into commands or signals intended for the peripheral device 9304. Such signals may direct the peripheral device to take some action, such as displaying text, displaying an image, activating an LED light, turning off an LED light, disabling a component of the peripheral device (e.g., disabling the left mouse button), enabling a component of the peripheral device, altering the function of the peripheral device, and/or any other action.
Application 9332 may include any program, application, or the like. Application 9332 may have an analogous function to application 9318 on the peripheral device 9304. In various embodiments, application 9332 may include a user-facing application, such as a spreadsheet program, a video game, a word processing application, a slide program, a music player, a web browser, or any other application.
AI module 9334 and database 9336 may have analogous functions to AI module 9320 and database 9322, respectively, on the peripheral device 9304.
Network interface controller 9338 may serve as an interface between the user device 9302 and the network 9310. In various embodiments, network interface controller 9338 may serve as an interface to one or more external devices. The interface controller 9338 may allow messages and data packets to be sent in both directions (e.g., both to and from user device 9302). When another module (e.g., application 9332) wishes to send a message over network 9310 and/or to a remote device, the module may use an API provided by the network data interface controller 9338 to do so. The interface controller 9338 may collect messages and data packets received by the user device and transmit them via operating system 9340 to the module that made the request or that is necessary to process them.
Although not shown explicitly, user device 9302, peripheral device 9304, central controller 110, and/or any other device may include such modules as: a text to speech translation module; a language translation module; a face recognition module; and/or any suitable module.
Although not shown explicitly, user device 9306 may have a similar set of modules as does user device 9302. Although not shown explicitly, peripheral device 9308 may have a similar set of modules as does peripheral device 9304.
Turning now to
Mouse device 9400 may include various components. Mouse device 9400 may include a processor 9405, network port 9410, connector 9415, input device 9420, output device 9425, sensor 9430, screen 9435, power source 9440, storage device 9445, AI accelerator 9460, cryptographic accelerator 9465, and GPU (graphics processing unit) 9470. Storage device 9445 may store data 9450 and program 9455. A number of components for mouse device 9400 depicted in
In various embodiments, connector 9415 may include any component capable of interfacing with a connection port (e.g., with connection port 315). For example, connector 9415 may physically complement connection port 315. Thus, for example, mouse device 9400 may be physically connected to a user device via the connector 9415 fitting into the connection port 315 of the user device. The interfacing may occur via plugging, latching, magnetic coupling, or via any other mechanism. In various embodiments, a mouse device may have a connection port while a user device has a connector. Various embodiments contemplate that a user device and a mouse device may interface with one another via any suitable mechanism. In various embodiments, a user device and a mouse device may interface via a wireless connection (e.g., via Bluetooth®, Wi-Fi®, or via any other means).
AI accelerator 9460 may include any component or device used to accelerate AI applications and calculations. AI accelerator 9460 may use data collected by sensor 9430 and/or input device 9420 to use as input into various AI algorithms to learn and predict outcomes. AI accelerator 9460 may use storage device 9445 for both input and result data used in AI algorithms and calculations.
In various embodiments, AI accelerator 9460 can send a signal back to user device 106a upon making a prediction, determination, or suggestion. For example, if a user is playing a game and it is determined by AI accelerator 9460 that the user is performing poorly a signal can be sent back to user device 106a to adjust the difficulty to a more appropriate level. It may also track a user's learning curve and be able to predict when the user will require a harder level.
In various embodiments, AI accelerator 9460 can use multifaceted data collected by sensor 9430 as input to induce actions. The accelerator can use this information, for example, to: trigger recording of the current game session when a user shows excitement through speech or skin response, induce a vibration in the mouse if the user is showing signs of being distracted or sleepy, etc.
In various embodiments, AI accelerator 9460 may combine data from various sources including sensor 9430 and input device 9420 with its own data calculated and/or stored on storage device 9445 over a long period of time to learn behaviors, tendencies, idiosyncrasies and use them for various purposes. For example, the AI accelerator may determine that the person using the mouse currently is not the approved user based on movement patterns, ambient sound, pressure applied to buttons, etc. and lock the computer to prevent unauthorized access. The accelerator may find concerning medical conditions through heart rate sensor, temperature, movement patterns and notify the user to seek medical attention. The accelerator may determine the user's learning capabilities and knowledge base to determine complexity settings on future games, applications, templates, etc.
Cryptographic accelerator 9465 may include any component or device used to perform cryptographic operations. Cryptographic accelerator 9465 may use data collected by various sources including but not limited to sensor 9430 and/or input device 9420 to use as input into various cryptographic algorithms to verify user identity, as a seed for encryption, or to gather data necessary for decryption. Cryptographic accelerator 9465 may use storage device 9445 for both input and result data used in cryptographic algorithms.
In various embodiments, cryptographic accelerator 9465 will encrypt data to ensure privacy and security. The data stored in storage device 9455 may be encrypted before being written to the device so that the data can only be usable if passed back through 9465 on output. For example, a user may want to store sensitive information on the storage device on the mouse so that they can easily authenticate themselves to any attached user device 106a. Using the cryptographic accelerator to encrypt the data ensures that only the given user can decrypt and use that data.
In various embodiments, cryptographic accelerator 9465 will encrypt signals to ensure privacy and security. Signals sent to user device 106a through connector 9415 and connection port 315 can be encrypted so that only a paired user device can understand the signals. Signals may also be encrypted by the cryptographic accelerator and sent directly via network port 9410 to another peripheral device 107a via that device's network port 410. For example, a user may use a microphone on their mouse to record speech for private communications and that data can pass through cryptographic accelerator 9465 and be encrypted before being transmitted. The destination device can decrypt using its cryptographic accelerator using shared keys ensuring no other party could listen in.
GPU (graphics processing unit) 9470 may include any component or device used to manipulate and alter memory to accelerate the creation of images in a frame buffer intended for output on one or more display devices. GPU 9470 may use data collected by various sources including but not limited to sensor 9430 or from the attached user device via connector 9415 to use in graphics processing. GPU 9470 may use storage device 9445 for reading and writing image data.
In various embodiments, GPU 9470 will create image data that will be displayed on screen 9435 or output device 9425. For example, a user is playing a game and GPU 9470 can be used to process data and display the data on mouse display (output device 9425), and can assist in processing graphics data.
In some embodiments, mouse device 9400 includes controller 9475 which can manage one or more devices 9480 in order to reduce the computational load on processor 9405.
Referring to
Component type identifier field 9502 may store an identifier (e.g., a unique identifier) for a particular type of component. Component description field 9504 may store a description of the component. This may indicate (e.g., in human-readable format) what the component does, what the function of the component is, what type of output is provided by the component, what type of input can be received by the component, what is the sensitivity of the component, what is the range of the component's abilities, and/or any other aspect of the component. For example, a component description may identify the component as an LED light, and may indicate the color and maximum brightness of the LED light.
Manufacturer field 9506 may store an indication of the component's manufacturer.
Model field 9508 may store an indication of the component model. This may be a part number, brand, or any other model description.
In various embodiments, information in table 9500 may be useful for tracking down component specifications and/or for instructions for communicating with a component.
Referring to
Component identifier field 9602 may store an identifier (e.g., a unique identifier) for a particular component (e.g., for a particular LED light on a particular mouse). Component type field 9604 may store an indication of the component type (e.g., by reference to a component type listed in table 9500). Reference name field 9606 may store a description of the component, which may include an indication of the component's location on or within a peripheral device. Exemplary reference names include “Left light #1”, “right LED #2”, “Front speaker”, and “Top left pressure sensor”. For example, if there are two LED lights on the left side of a mouse, and two LED lights on the right side of a mouse, then a reference name of “Left light #1” may uniquely identify a component's location from among the four LED lights on the mouse.
Address field 9608 may store an address of the component. This may represent a hardware address and/or an address on a signal bus where a component can be reached.
Referring to
Signal identifier field 9702 may store an identifier (e.g., a unique identifier) for a particular signal. Component type field 9704 may store an indication of the component type for which the signal applies.
Incoming/Outgoing field 9706 may store an indication of whether a signal is outgoing (e.g., will serve as an instruction to the component), or is incoming (e.g., will serve as a message from the component). Description field 9708 may store a description of the signal. The description may indicate what the signal will accomplish and/or what is meant by the signal. Exemplary descriptions of outgoing signals include “turn the light on” (e.g., an instruction for an LED component), “Turn the light on dim”, and “tone at 440 Hz for 0.5 seconds” (e.g., an instruction for a speaker component).
Signal field 9710 may store an actual signal to be transmitted to a component (in the case of an outgoing signal), or a signal that will be received from a component (in the case of an incoming signal). As depicted, each signal is an 8-bit binary signal. However, various embodiments contemplate that a signal could take any suitable form. In the case of an outgoing signal, when a component receives the signal, the component should accomplish what is indicated in the description fields 9708. In the case of an incoming signal, when the signal is received (e.g., by component driver 9312), then the signal may be interpreted as having the meaning given in description field 9708.
In various embodiments, a complete instruction for a component includes a component address (field 9608) coupled with a signal (field 9710). This would allow a signal to reach the intended component, (e.g., as opposed to other available components). The component could then carry out a function as instructed by the signal.
Referring now to
At step 9803, peripheral 1 receives a series of signals from components. These may be components of the peripheral device such as input device 9420 and/or device 9480. Exemplary signals originate from button clicks (e.g., button clicks by a user), key presses, scrolls of a mouse wheel, movements of a mouse, etc.
Initially, signals may be received at component driver module 9312. As the signals are incoming signals (i.e., incoming from components), table 9700 may be used to interpret the meaning of such signals (e.g., “click of the right mouse button”). In various embodiments, signals are received at ‘user input output controller 9316. In various embodiments, signals received at component driver module 9312 are then passed to ‘user input output controller’ 9316, e.g., by way of operating system 9326.
At step 9806 peripheral 1 aggregates such signals into an intended message. Thus far, peripheral 1 only recognizes the received signals as a collection of individual component activations (e.g., as a collection of clicks). At step 9806, peripheral 1 may determine an actual message (e.g., a human-interpretable message; e.g., a text message) that is represented by the component activations.
The component driver 9312 or the user inputs/output controller 9316 may pass its interpretation of the incoming signals to the application 9318. The application may then aggregate, combine, or otherwise determine a message intended by the signals. Application may reference ‘Generic actions/messages’ table 2500 or ‘Mapping of user input to an action/message’ table 2600 in database 9322, in order to determine an intended message. In various embodiments, the signals may represent characters or other elementary components of a message, in which case such elementary components need only be combined (e.g., individual characters are combined into a complete text message). In various embodiments, a message may be determined using any other data table, and/or in any other fashion.
In various embodiments, there may not necessarily be a precise correspondence between incoming signals and a message. For example, mouse movements (e.g., gestures) may be representative of words or concept in American Sign Language. However, the precise boundaries between a gesture representing one concept and a gesture representing another concept may not be clear. In such cases, AI module 9320 may be used to classify a mouse movement as representative of one concept versus another concept. In various embodiments, AI module 9320 may be used in other situations to classify signals into one intended meaning or another.
At step 9809 peripheral 1 conveys the intended message to user device 1. Once application 9318 has determined the intended message, the application may pass the message to the computer data interface controller 9324. The message may then be encoded and transmitted to user device 1 (e.g., via USB, via firewire, via Wi-Fi®, etc.)
At step 9812 user device 1 receives the intended message at its computer data interface controller 9328. The received message may then be passed to peripheral device driver 9330, which may need to transform the message from a format understood by the peripheral device 9304 into a format understood by user device 9302 (e.g., by the operating system 9340 of user device 9302).
At step 9815 the peripheral device driver passes the message to a user device application (e.g., application 9332). In various embodiments, in accordance with the present example, application 9332 may be a messaging application that works in coordination with peripheral device 9304. The messaging application may maintain a running transcript of messages that have been passed back and forth to peripheral device 9304. In this way, for example, a user may scroll up through the application to see old messages in the conversation. However, in various environments, application 9332 on the user device may serve only as a relayer of messages.
At step 9818 the user device application passes the intended message through the Internet to the central controller 110. Application 9332 may initially pass the message to the network data interface controller 9338, where it may then be encoded for transmission over network 9310. In various embodiments, application 9332 may include an intended recipient and/or recipient address along with the message.
At step 9821 the central controller passes the message through the Internet to user device 2 (e.g., to user device 9306). In various embodiments, the central controller 110 may also log the message (e.g., store the message in a data table such as ‘Peripheral message log’ table 2400).
At step 9824 the message is received at an application on user device 2. The message may initially arrive at a network data interface controller of ‘user device 2’ 9306 before being decoded and passed to the application.
At step 9827 the application on user device 2 passes the message to a peripheral device driver.
At step 9830 the peripheral device driver passes the message to peripheral 2. In various embodiments, the peripheral device driver may pass the message by way of a computer data interface controller. Peripheral 2 may receive the message at its own computer data interface controller, where the message may be decoded and then passed to an application on peripheral 2.
At step 9833 peripheral 2 determines a high-level message. In various embodiments, a high-level message may be determined in an application. Example messages may include, display the text “Good going!”, create a “wave” of green LEDs, output an audio jingle with the notes “C-C-G-G-A-A-G”, etc.
At step 9836 peripheral 2 determines components required to convey the message. For example, if a message includes text or images, then a display screen, an LCD display, or any other suitable display may be used to convey the message. In various embodiments, if a message is text, then the message may be conveyed by depressing or lighting keys on a keyboard peripheral. If the message involves lights (e.g., sequences of light activation), then LEDs may be used to convey the message. If the message involves audio, then a speaker may be used to convey the message. In various embodiments, a message may be intended for more than one modality, in which case multiple components may be required.
Peripheral 2 may determine available components with reference to a database table, e.g., to table 9600. Table 9600 may also include component locations, so that peripheral 2 may determine the geometrically appropriate component required to convey a message (e.g., peripheral 2 may determine which is the frontmost LED as required by a message). In various embodiments, the application on peripheral 2 may determine the required components.
At step 9839 peripheral 2 determines component states required to convey the message. Component states may include whether a component is on or off, the intensity of an output from a component, the color of an output, the degree of depression of a key, and/or any other state. Exemplary component states include a light is green, a light is red, a light is dim, the “x” key is depressed by 1 mm, etc. In various embodiments, the application on peripheral 2 may determine the required component states.
At step 9842 peripheral 2 determines an activation sequence for the components. An activation sequence may specify which component will activate first, which will activate second, and so on. In various embodiments, an activation sequence may specify a duration of activation. In various embodiments, two or more components may be activated simultaneously and/or for overlapping periods. In one example, an LED goes on for five seconds, then a haptic sensor starts vibrating, etc. In various embodiments, the application on peripheral 2 may determine the activation sequence.
At step 9845 peripheral 2 determines instructions to create the states in the components. In various embodiments, determining instructions may entail determining component addresses and determining signals to transmit to the components. In various embodiments, component addresses may be obtained by reference to a database table, such as to table 9600 (e.g., field 9608). In various embodiments, signals may be obtained by reference to a database table, such as to table 9700 (e.g., field 9710). Since such signals will be part of instructions to a component, such signals may be listed as “outgoing” at field 9706. A complete instruction may be assembled from the address and from the signal to be sent to that address. For example, given an 8-bit address of “10010101”, and an 8-bit signal of “11101110”, a complete instruction may read “1001010111101110”. In various embodiments, instructions may be determined in an application, in a user input/output controller and/or in a component driver of peripheral 2.
At step 9848 peripheral 2 issues the instructions according to the activation sequence. The instructions determined at step 9845 may be sequentially transmitted (e.g., at appropriate times) to the various components of peripheral 2. The instructions may be transmitted by a user input/output controller and/or by a component driver of peripheral 2. In various embodiments, an application may govern the timing of when instructions are issued. With instructions thus issued to a peripheral's components, the message may finally be related to the second user. E.g., user 2 may see on his mouse's display screen the message, “Good going!”.
Process 9800 need not merely relate to inputs intentionally provided by a first user, but may also relate to actions, situations, circ*mstances, etc. that are captured by peripheral 1, or by other sensors or devices. In various embodiments, one or more sensors on peripheral 1 (or one or more other sensors) may capture information about the first user (e.g., the first user's breathing rate) and/or about the first user's environment. Sensor data may be aggregated or otherwise summarized. Such data may then be relayed ultimately to the second user's peripheral device, peripheral device 2. Peripheral device 2 may then determine how the data should be displayed, what components are needed, what states are needed, etc. User 2 may thereby, for example, receive passive and/or continuous communication from user 1, without the necessity of user 1 explicitly messaging user 2.
In various embodiments, a message transmitted (e.g., from peripheral 1 to peripheral 2) may include intentional inputs (e.g., inputs explicitly intended by user 1) as well as data passively captured about user 1 and/or user 1's environment. For example, if user 1 sends a “hello” text-based message to user 2, and user 1 is eating, the fact that user one is eating may be captured passively (e.g., using cameras) and the “hello” message may be rendered for user 2 on the image of a dinner plate.
Referring now to
In various embodiments, the peripheral device may be a first mouse operated by a first user. The first mouse may comprise an output component operable to generate human-perceptible output. The output component may include a light, speaker, or any other output component. The output component may be operable to generate human-perceptible output at varying intensities (e.g., varying brightness; e.g., varying volume).
In various embodiments, the user device may be a computer. The computer may comprise an electronic processing device (e.g., a processor). The computer may comprise a network device in communication with the electronic processing device. The computer may comprise a memory storing instructions that, when executed by the electronic processing device, may result in performance/execution of process 9900.
At step 9903, the user device may receive, by the network device and from a remote computer, an indication of a first reading from a first sensor of a second mouse operated by a second user (e.g., a friend of the first user). The first sensor may be a biometric device, which may capture heart activity, or any other activity.
At step 9906, the user device may classify a first action of the second user based on the reading from the first sensor. In various embodiments, the user device may thereby determine that the second user is available (e.g., to play a game).
At step 9909, the user device may identify, based on the classification of the first action, a first output command comprising an instruction defining a first output for the first mouse.
At step 9912, the user device may output, by the first mouse and in response to the first output command, the first output. In various embodiments, the output may be light (e.g., at some specified intensity; e.g., at some specified color).
In various embodiments, process 9900 may be performed by any suitable device, such as a user device of a first user, a user device of second user, a peripheral device of a first user, a peripheral device of a second user, the central controller 110, and/or any other device.
Mouse and Keyboard Logins
In some embodiments, a mouse and/or keyboard may log into a user computer by transmitting a signal representing mouse movement or a keyboard character (e.g., a space bar character) in order to wake up a user computer. At that point, one or more usernames and passwords may be passed from a mouse and/or keyboard in order to log into the user device. Once logged in, the mouse and/or keyboard may then get access to the operating system of the user computer in order to read or write data. In some embodiments, a mouse logs into a user computer on a scheduled basis (e.g., every 20 minutes) in order to gather information about the status of another user. For example, software on the user computer may request status updates stored at central controller 110 every time the user computer is woken up. If there are any new updates since the last query, that information is then transmitted to storage device 9445 of the user computer. In embodiments in which a mouse or keyboard autonomously logs into a user computer periodically in order to receive status updates relating to one or more other users, some functionality of the mouse may be disabled when a user is not present. For example, the xy positioning data generated by mouse movements may be disabled during these autonomous logins so that an unauthenticated person trying to use the mouse while it is logged into the user computer to get status updates will not be able to generate any xy data and will thus be unable to perform any actions with the user computer while it is activated by the autonomous logins.
Mouse and Keyboard Security
In some embodiments, a mouse may be used in a way that supplements the security of a user device. For example, passwords and cryptographic keys may be stored in storage device 9445, or within encryption chip 9465. These keys may be transmitted to a user device in order to wake up and/or login to the user device. In such embodiments, passwords stored within the mouse may be more secure than those stored in the memory of a user device because the operating system of the mouse will not be familiar to potential attackers seeking to obtain (e.g., via hacking) those passwords or cryptographic keys. In embodiments in which a mouse autonomously logs into a user computer periodically in order to receive status updates relating to one or more other users, some functionality of the mouse may be disabled when a user is not present. For example, the xy positioning data generated by mouse movements may be disabled during these autonomous logins so that an unauthenticated person trying to use the mouse while it is logged into the user computer to get status updates will not be able to generate any xy data and will thus be unable to perform any actions with the user computer while it is activated by the autonomous logins.|
Referring to
With reference to
In various embodiments, the app allows an observer to configure one or more parameters of a headset. In some embodiments, the app may allow a tutor to select one of the sensors worn by student 8405 to be shown in app 8400.
Call Platforms
With reference to
Display 8500 includes a GUI that represents callers in a single gallery view 8505. In this illustration, there are eight grid locations 8510 within the gallery view 8505, each of which contains one of callers 8515a-h. In this embodiment, a caller can see an image of other callers while verbally interacting with them. In some embodiments, the effectiveness of virtual meetings/calls is enhanced by allowing users to set a preferred grouping or ordering of gallery view 8505 based on a user's preferences—such as grouping caller images by hierarchy, job function, seniority, team, meeting role, etc. Call participants can take direct actions to manage the gallery view 8505 of participants on a call in a way that enhances the user's call experience. Call participants could be provided the ability to move the images of callers 8515a-h around during a call, ordering and placing the images in a way that is most beneficial to the user. For example, a user could click on caller image 8515a-h and drag that image to a new grid location 8510. A user could drag multiple gallery images to form a circle, with the new image locations stored in an image location field of a gallery database stored with the central controller or call platform software. This stored set of image locations forming a circle could be associated with a keyword such that the user could, upon the initiation of subsequent similar calls, type in the keyword to retrieve the desired locations and have the current gallery images placed into a circular arrangement. A user could also double click on a caller image to remove it, gray it out, make it black and white, make it more transparent, eliminate the background, or crop it (such as cropping to non-rectangles such as circles or ovals), or make the image smaller.
Caller images 8515a-h can include still photos of the user, a drawing of the user, a video stream of a user, etc. In one embodiment of the present invention, a user can create a cartoon character as a video call avatar that embodies elements of the user without revealing all of the details of the user's face or clothing. For example, the user could be represented in the call as a less distinct cartoon character that provided a generic looking face and simplified arms and hands. The character could be animated and controlled by the user's headset (or a webcam of the user's computer detecting head movement). A user might create a cartoon character, but have his headset track movement of his head, eyes, and mouth. In this embodiment, when the user tilts his head to the left an accelerometer in his headset registers the movement and sends the movement data to the headset's processor and then to the call platform software which is in control of the user's animated avatar, tilting the avatar's head to the left to mirror the head motion of the user. In this way, the user is able to communicate an essence of himself without requiring a full video stream. The user could also provide a verbal command to his headset processor to make his avatar nod, even though the user himself is not nodding. One of the benefits to using an avatar is that it would require significantly less bandwidth to achieve (another way to reduce bandwidth used is to show a user in black and white or grayscale). The user's headset processor could also use data from an inward looking video camera to capture movement of the user's eyes and mouth, with the processor managing to send signals to the central controller or directly to the call platform software to control the user's avatar to reflect the actual facial movements of the user. In this way, the user is able to communicate some emotion via the user's avatar without using a full video feed.
While gallery views usually show just the face and name of the user, there is a lot of information about users that could be displayed as well. Such information could include what a call participant is thinking at that moment, which would allow for more informed and effective actions by the other call participants. Additional information could also include social information that could help other call participants get to know a user, or as an icebreaker at the start of a meeting. For example, the user might provide names of children and pets, favorite books, games played, sporting activities, and the like. In some embodiments, each caller has associated additional flip side information 8520 that can be seen by other callers by using a‘Flip’ command 8540 to flip the caller image over to reveal the additional image on the back like looking at the reverse side of a baseball card. User image 8515c is illustrated as having been flipped to the back side, revealing that user 8515c has worked with the company for 13 years, currently works in New York City, and has three kids.
Alterations to the way in which call participants are displayed in the image gallery could be based on sensor data received and processed by the call platform software. In another embodiment, a user's heart rate could be displayed alongside a user image 8515. For example, the user's mouse (not shown) could be equipped with a heart rate sensor which sends a signal representing the user's heart rate 8522 to the call platform software (or central controller 110) in order to identify when a caller might be stressed. As illustrated, caller 8515d has an icon next to her caller image that indicates that her current heart rate is 79 beats per minute. In various embodiments, other biometric data (e.g., galvanic skin response) can be displayed alongside a user image. Supplemental background information 8523 could include information such as team affiliation, functional area, level, skill sets, past work/project history, names of their supervisors, etc. In the illustration, user 8515h has background information 8523 which indicated that he is an ‘IT Lead’ and is currently working on ‘Project x’. The information could also include what the user is currently thinking (e.g., they want to respond to the last statement). In another example, a meeting owner could assign roles to call participants during the call, with those assigned roles appearing as supplemental information such as by adding a label of “note taker” below a call participants gallery view image. Supplemental information could include dynamic elements, such as showing a user's calendar information or current tasks that they are working on. Other dynamic supplemental information could include statistics around the meeting, such as the current average engagement level, percentage of agenda items completed, number of current participants, etc. This dynamic supplemental information could be about an individual, such as showing the user's current engagement level, talk time, number of tags placed, number of agenda items completed, badges received, etc.
In some embodiments, there are times on a call when a user would like to communicate with another call participant, but the number of participants makes that difficult to do without waiting for an opportunity to speak. In such embodiments, a user could communicate via a caller border 8525 around their caller image 8515a-h while on the call. For example, a user could double click on their caller image in order to have the caller border 8525 flash three times or change color in order to quickly get the attention of other call participants. In another example, the user could communicate by changing the color of their caller border 8525 to red if they would like to make a candid statement or green if they are feeling very in tune with the other participants. In the current illustration, caller 8515b has elected to make the frame of caller border 8525 bolder in order to indicate that he is waiting to say something important. In addition to changing the look of the user's gallery view image, the present invention can also allow a call participant to see the ways that call participants are connected, revealing information that could help to enhance the effectiveness of the meeting. For example, callers 8515h and 8515g have a visible alignment 8530 indication. This alignment could be determined by call platform software in conjunction with central controller 110. For example, central controller 110 could determine that these two callers are both working to move a particular company software application to the cloud. Alignment 8530 could also reflect meeting ratings stored with central controller 110, with two callers aligned if their ratings were more than 90% the same.
In some embodiments, call participants can use call functions 8533 to provide more information to other users, reveal more information about other users, provide rewards and ratings to other users, indicate that they have a question about another user, etc. With a set alignment button 8535, a user could identify two callers who seem to be aligned in some way and have that alignment 8530 made visible to other call participants. A ‘flip’ button 8540 could allow a user to flip a second user's image to reveal additional information about that second user. A note 8542 could allow a user to attach a note to a second user's grid location 8510 or caller image 8515. The note might be a question, a comment, a clarification, a drawing, etc. In some embodiments, callers have access to tags 8545 which can be placed onto grid locations 8510 associated with other users. For example, a user might show some appreciation for an insightful statement from caller image 8515d by dragging a star symbol into her grid location. This star might be visible only to caller 8515d, only to members of her functional group, or visible to all call participants. The star could remain for a fixed period of time (e.g., two minutes), remain as long as the call is in progress, disappear when caller 8515d clicks on it, disappear when caller 8515d stops speaking, etc. Other examples of tags being provided to other users in this illustration include two ribbon tags 8545 attached to caller 8515g, a star symbol attached to alignment 8530 and to caller 8515f and to caller 8515d, a question tag 8545 attached to caller 8515b indicating that another user has a question for him, and coin tags 8545 associated with caller 8515a (two coins) and one coin associated with caller 8515e. In the example of coins, these might be convertible into monetary benefits or might be exchangeable for digital assets like music or books. Such coins might encourage productivity and focus during calls as users seek to ‘earn’ coins with helpful comments, new ideas, good facilitation, etc. Many other suitable tags could be used for different purposes.
In other embodiments, modules area 8550 contains one or more software modules that could be selectable by users or established by meeting owners prior to a meeting. These modules can provide functionality which can enhance the effectiveness of a virtual call. For example, chat area 8555 allows call participants to chat with each other or to the group. A presentation module 8560 could show a thumbnail view of a presentation slide, which users could click on to enlarge it to full screen. Callers could also add comments or questions to a particular slide. In the illustrated example, a quarterly sales chart is shown on page 4 of the presentation. One caller is unclear about an aspect of the chart and adds a question symbol to alert the meeting owner or other callers that something is not clear. A speaker queue 8565 could allow callers to enter into a queue to speak during the call. In large meetings, it is common for one person to make a statement and for others to then want to verbally respond. But if there are many who want to respond, there is often a confusing time when multiple people are trying to respond at the same time, creating some chaos that is disruptive to the meeting.
The call platform software could determine a speaking queue by receiving requests from call participants who want to speak. As this queue is adjusted, the participants waiting to speak could be displayed in the gallery in speaking order. As the individual approaches their time to speak, the border 8525 on the gallery could begin to change colors or flash. In another example, the call platform software determines the order of the next five speakers and places a number from one to five as an overlay on top of each of the five participant's images, so the next participant due to speak has a number one on their image, the second has the number two, etc. In some embodiments, participants who want to speak could be presented with the ability to indicate how their contribution relates to elements of the conversation. An individual who wishes to speak could be presented with choices such as “I have the answer to your question”; “I agree”; “I want to offer an example;” “I'd like to highlight something that was just said”; “I want to offer a different opinion”; “I think that's not relevant;” “I want to summarize the discussion”; “I'd like transition or move on”; “I'd like to ask for a poll” “I'd like to ask for the feeling of the room” “I'd like to ask a question”; “I'd like us to take an action or make a decision.” Participants could fill a short text box with information about what they are going to say. When individuals select an option to indicate how they want to contribute or input a description of what they want to say, the type of their contribution or their rationale could be visually indicated to others on the call.
In another embodiment, individuals could select from digital representations associated with contribution types known as “intenticons.” Intenticons are abstract representations of intent similar to emojis or emoticons. The intenticon could be displayed next to the participant's name, could replace the participant's name, could be placed above, below, around or composited on top of the participant's image, or could replace the participant's image. Call participants who want to respond to a current speaker could enter text summarizing the nature of their response, allowing call platform software to merge one or more responses or bump up the priority of one or more responses. For example, two users might want to respond by pointing out a security issue brought up by the current speaker, in which case the call platform software picks only one of those responses to be made, sending a message to the other responder that their response was duplicative. Information about a potential responder's response could change the prioritization level, such as by a user who wants to bring up a potential regulatory issue with a previous statement.
In some embodiments, the meeting owner could allow participants to indicate which other participants they would like to hear next. For example, participants could reorder a visual queue containing the contributions or the names of participants in the speaking queue. For example, participants could click on other participants' images 8515a-h, grid locations 8510, or contributions to indicate. By indicating, the call platform could change the visual representation of the gallery view to highlight individuals that others think should talk next. A highlighted frame could appear around the user, or the user could be placed in a spotlight, for example. In other embodiments, individuals could upvote or downvote individuals in a speaking queue by clicking on a button indicating thumbs up/down, “speak next”/“don't speak next”, or left mouse clicking or right mouse clicking, swiping left or swiping right. Individuals could remove themselves from the speaking queue. In one embodiment, the participant could click a “never mind” button. In another embodiment, a participant could remove oneself by right clicking on a visual representation of the queue and selecting an option to remove oneself. In various embodiments, a configuration may specify an order of speakers or presenters.
Exercise Reminders
As modern workers increasingly sit all day doing information work, they run the risk of developing health issues if they do not get up and take occasional breaks to stretch and move around. In various embodiments, when a meeting participant has been in a long meeting, the chair could send a signal to the room controller indicating how long it had been since that participant had stood up. If that amount of time is greater than 60 minutes, for example, the central controller could signal to the chair to output a series of three buzzes as a reminder for the participant to stand up. The central controller could also send a signal to the meeting owner that a ten-minute break is needed for the whole room, or even initiate the break automatically. The central controller could send signals to smart variable-height desks to automatically adjust from sitting to standing position as an undeniable prompt that participants should stand up. In various embodiments, if the central controller identifies a meeting participant who is in back to back meetings for four hours straight, it could send a signal to the participant device with verbal or text reminders to stretch, walk, take some deep breaths, hydrate, etc. In various embodiments, if a meeting participant is scheduled for four hours of meetings in a row, the central controller could send the participant alternate routes to walk to those meetings which would take more steps than a direct route. In various embodiments, for virtual meeting participants, the central controller can also send reminders to participants that they should take a break and walk outside or spend a few minutes doing stretching/exercising. These suggestions could be linked to heart rate readings from a mouse, slouching or head movements seen by a camera, a fidgeting signal from a chair, etc.
Mental Fitness
As employees perform more and more information-driven work, keeping their minds functioning well is more critical than ever. An employee who is tired, distracted, unable to focus, or perhaps even burned out will have a hard time performing complex analytical tasks. Research has shown, for example, that software developers need large blocks of uninterrupted time in order to write good software. If their minds are not sharp, significant business value can be lost. In various embodiments, the central controller reviews the meeting schedule of all knowledge workers in order to assess the impact that the schedule may have on the mental fitness of the employee. For example, when the central controller sees that an employee has back to back meetings for a six hour block on two consecutive days, the employee may receive direction in ways to reduce some of the stress associated with those meetings. Stress alleviation suggestions could include: Meditation; Exercise (e.g., light yoga, stretching); Healthy snacks; Naps; Fresh air; Focus on a hobby or something of personal interest; Calming videos or photos; Positive/encouraging messages from company leadership; or any other suggestions. The central controller reviews the meetings of the knowledge worker and compares them to other knowledge workers in similar roles to see if any are getting oversubscribed. For example, if certain key subject matter experts are being asked to attend significantly more innovation meetings than other subject matter experts, the central controller can alert the management team of possible overuse. In addition, the overused subject matter expert could be alerted by the central controller to consider delegating or rebalancing work in order to maintain a healthy lifestyle. In the converse, as an example, if a subject matter expert or key role (e.g., decision maker) individual is currently undersubscribed compared to others, the central controller can alert management or other meeting leads to put this person at the top of the list if they have a need for this expertise.
In various embodiments, the central controller 110 may review information collected about a meeting participant to look for signs that an employee may be heading toward burning out. Such signals could include the employee is: Using a loud voice in a meeting; Having a rapid heartbeat; Slouching or not being engaged with other participants; Interrupting other participants; Declining meetings at a more significant rate than most in similar roles; Significantly more out of office or absentees in a short period of time; Changes in level of meeting engagement; No breaks for lunch; or any other signals. In various embodiments, the central controller 110 can also monitor biometric information (such as heart rate, posture, voice, blood pressure) and compare the results to the entire organization to determine if the pattern is higher than expected. For example, if the individual on the verge of burnout shows that they are interrupting individuals using a loud voice more frequently than most, the central controller can alert the individual during the meeting to consider alternative approaches for engagement such as, taking a break, breathing deeply, meditating or any predetermined approaches deemed appropriate by the organization. If the data continue to support potential burnout, the central controller can inform the individuals management for intervention and coaching. In various embodiments, the central controller 110 can interrogate the calendars of individuals to determine if they are getting uninterrupted time for lunch during a specific time. For example, the central controller can look at an individual's calendar over a month time period. If the time slot between 11:30 AM-1:30 PM is consistently booked with meetings more than 50% of the time, the central controller can alert the individual to reconsider taking lunch breaks for healthy nutrition and also inform meeting leads that the use of lunch meetings could be excessive.
In various embodiments, the central controller 110 could also have the ability to look at the home calendar of employees so that it has an understanding of how busy they might be outside of work. For example, the central controller can look to see if exercise routines are typically scheduled on an individual's calendar. If so, and suddenly they begin to not appear, the central controller can provide reminders to the individual to reconsider adding exercise routines to their calendar to maintain a healthy lifestyle. Another example could be for the central controller to view events on an individual's calendar outside of normal work hours (pre-8:00 AM and post-5:00 PM) to determine if enough mental free time is being allocated for mental health. If calendars are continually booked with dinner events, children's events, continuing education or volunteer work without time for rest, this could be early signs of burnout. The central controller could remind the individual to schedule free time to focus on mental rest, prioritize activities and provide access to suggested readings or activities to promote mental wellbeing. In various embodiments, the central controller 110 can maintain analytics on the number of declined meetings that are typical in an organization and compare to an individual. If the number of declined meetings for the individual is higher than average, helpful information can be provided. For example, if the organization typically has 5% of their meetings declined and meeting participant “A” has an average of 25% of meetings declined, the central controller can prompt to individual to consider other alternatives to declining a meeting such as delegating, discussing with their manager any situation prompting them to decline meetings, or make use of mental and physical wellness activities for improvement. Many enterprise organizations have access to an array of mental and physical health content and individual health providers via the insurance companies that provide health benefits. The central controller could identify these individuals and direct them to their health insurance provider. This immediate intervention and access to a professional in the field of mental health via their insurance providers could help mitigate the health issues.
Virtual Audience Feedback
When presenting at a meeting which has a high percentage of virtual participants, it can sometimes be disconcerting for a presenter to speak in front of a largely empty room. In various embodiments, one or more video screens are positioned in front of the speaker to provide images of participants, and to guide the presenter to make head movements that will look natural to virtual participants. In various embodiments, color borders (or other indicia) may be used for VPs, or other key people. In various embodiments, three people (e.g., stand-in people) are set up before the call (can be dynamic based on what slide the presenter is on). The presenter can then practice presenting to these three people. In various embodiments, it is oftentimes important to know the roles or organizational level of individuals in a meeting to make sure that the presenter is responding appropriately. For example, if a Decision meeting is taking place, it is important to quickly be able to identify these individuals so you can speak more directly to them. The central controller could gather this information from the meeting presenter in advance. Once they join the meeting, their images could have a border in a different thickness, pattern or color to more easily identify them. Since they are the key members in this particular meeting, their images could display larger than others and be represented on the various display devices. If any of these individuals speak, the central controller could adjust the border to brighten in color, flash a particular pattern and gray out the images of others. This allows the presenter to quickly focus on the key participant speaking and make better eye contact.
In various embodiments, an audience (emoji style) is displayed to the presenter. In meeting settings it is important to connect with the audience and even more so in a virtual meeting. Each meeting attendee can provide an image of themselves or use an already approved picture via a corporate directory to the central controller. When the meeting begins, the individual images are presented on the various display devices. As emotions and biometric data is collected by the central controller, the emoji can change to reflect the state of the individual. If the audience is happy, the emojis change to provide the presenter immediate feedback. Conversely, if the central controller detects the audience is confused or frustrated, the emoji changes immediately to reflect the new state. This feedback allows the presenter to collect real time audience information and adjust their presentation accordingly. Furthermore, if a presenter needs to practice a presentation remotely in advance of the live presentation, the central controller can present a random set of emojis and images for the presenter to practice. In various embodiments, a real-time emoji dashboard is displayed to the presenter for selected reactions. The central controller should allow the meeting participants to provide emoji style feedback to the presenter in real time. For example, if a presenter is training an audience on a new product and some attendees are confused, others are happy and some are bored, the audience members can provide the appropriate emoji to the presenter. The central controller collects all emojis and displays them in dashboard format to the presenter. In this case, 10 confused emojis, 50 happy emojis and 2 bored emojis appear on the dashboard bar chart for interpretation by the presenter. They may elect to pause and review the slide showing 10 confused faces. In addition, the central controller could record the emotions on each slide, along with the participant, and inform the presenter. After the meeting, the presenter can address the reaction on each slide with those that had the issue/concern.
In various embodiments, feedback can be presented to the speaker/coordinator/organizer in a graphical form that privately (or publicly) parses out responses, statuses, etc., by attendee. The speaker can easily view, for example, who has provided an answer to a question (e.g., a poll) and who still needs to answer. In various embodiments, as presenters are speaking, a feeling thermometer dynamic dashboard is presented for review and real-time adjustments to their presentation. For example, the central controller could provide each participant with an opportunity to rate the presentation using a feeling thermometer based on any dimension the meeting owner selects. Is the presentation material clear? The participant can adjust the thermometer to indicate very clear to very unclear. The collective ratings of all thermometer scores is dynamically presented to the presenter for any needed adjustments. In addition, the pace at which a presentation is being delivered can also be measured and presented on the dashboard as well.
Virtual Producer
As meetings become more virtual, it may be increasingly important for meeting owners and meeting participants to maintain a natural look during meetings. The way that they are looking and the angle of the head will convey a lot of non-verbal information. In this embodiment, the central controller uses software to make suggestions to participants and to pick camera angles much like a producer would in a control room of a television news show which can do things like cut to the best camera angle or include a small video frame to support the point that the presenter is making. In various embodiments, there are three cameras (or some other number have cameras) and the system picks the best angle. For example, the central controller 110 identifies who is speaking and where they are in relation to the display you are using. When you look in the direction of the person speaking (virtually or not) the appropriate camera focuses the angle in the direction you are looking. In various embodiments, the system tells you how to turn when you are on video. For example: As a presenter to a virtual audience, you may need to turn your head to appear to speak to a larger audience and not give the appearance that you are staring at them. The central controller can track how long you are focused in one direction and prompt you to move your head and look in a different direction. This provides a more realistic view of the presentation to the audience and can put them at ease as well.
In various embodiments, the presenter talks with his/her hands, the camera should zoom out. The central controller 110 could determine if you are using your hands to speak more or illustrate a point. Your hands and arms may appear to come in to focus more often. In this case, the central controller could communicate with the camera to zoom out and pick up movements in a larger frame. Pan-Tilt-Zoom (PTZ) camera can be auto controlled by the system to meet production goals (e.g., zoom in to emphasize speaker as speaker volume or role increases). In various embodiments, a meeting lead can determine if other speakers are brought in to view or remain focused on them only. Example: if I am a lecture or in a town hall, I may only want the camera in me and not go to others. The meeting lead can interact with the central controller in advance of the meeting to determine if participants will be brought in to focus during the meeting. If the preference is to not allow the participant to be in focus, when they speak, the central controller will not display the individual, but camera focus will remain on the presenter/meeting lead. In various embodiments, the system may bring participants in or out of focus. When a speaker comes in to focus, the other participants gray out or turn to a different hue. This forces people to focus on the person speaking. For example, in interview situations, question/answer sessions or learning meetings, it is important that the vast majority of participants stay focused on a primary individual. When an individual begins to speak for a few seconds, they quickly come into focus while the others are displayed in a monochromatic display. In this case, the eyes of the participants are drawn to the speaker that remains in full color. In various embodiments, the system determines if focus is on the content displayed or the presenter. During a presentation, while the attendees may be listening and watching the presenter, they are interested in the presentation content as well. In advance of the presentation, the presenter can set a preference via the central controller to make the presentation deck the main focus and a small image of the presenter in the corner of the screen. The central controller could know when the presentation is complete and refocus on the presenter. If the presenter goes back to the slide presentation, the central controller can revert back to the original setting.
Eye Tracking
Tracking where participants are looking can be very helpful in evaluating presentations and estimating the level of meeting participant engagement. Various embodiments track where on a slide that participants are looking. This could provide an indication of the level of engagement of the audience. Various embodiments track where in the room participants are looking. Automatically identify potential distractions; prompt the meeting owner or a particular meeting participant to turn off TV, close window blind, etc. Various embodiments track which other participants a participant is looking at and when. For example, the central controller could track eye movements of people to determine if an issue exists. If multiple participants look over at someone working on a laptop/phone this may mean they are frustrated with this person because they are not engaged. The central controller could track eye movements of people coming and going from the room which may be an indication that a break is needed. If a meeting participant is routinely looking at another participant during a presentation, this could indicate they are not in agreement with the content and looking for affirmation from another participant. Various embodiments include tracking eye rolling or other visual cues of agreement or disagreement. For example, if eyes roll back or are simply staring, this could indicate they are in disagreement with the topic or person and inform the meeting owner.
Gesture Tracking
With cameras, GPS, and accelerometers, there are many physical gestures that can be tracked and sent to the central controller. Example gestures include: arms folded; holding up some number of fingers (e.g., as a show of support or objection to some proposition; e.g., a fist of five); hands clasped together or open; clapping; fist on chin; getting out of one's chair; pushing back from a table; stretching or fidgeting. Some gestures of possible interest may include head movement. In various embodiments, head movement can be an excellent way to provide data in a natural way that does not disrupt the flow of the meeting. Head movements could be picked up by a video camera, or determined from accelerometer data from a headset, for example. In various embodiments, virtual participants could indicate that they approve of a decision by nodding their head, with their headset or video camera sending the information to the room controller and then summarizing it for the meeting owner. Participants could also indicate a spectrum of agreement, such as by leaning their head way left to indicate strong disagreement, head in the center for neutrality, or head far to the right to indicate strong agreement. In various embodiments, virtual participants could enable muting of their connection by making a movement like quickly looking to the right. For example, when a dog starts to bark, it is natural for participants who are not muted to look in the direction of the dog or child making noise, which would automatically mute that person. They could be muted for a fixed period of time and then automatically be taken off mute, or the participant could be required to go back off mute when they are ready. Virtual participants could also make a gesture that would bring up a background to hide something. For example, a participant who had a small child run up behind them while on a video call could tip their head backward to bring up the background which would prevent others on the call from seeing the child.
Verbal Queues not Intended for Meeting Participants
There are times when meeting participants make soft comments that are not meant to be heard by the meeting participants or that are not understood by the participants. These verbal queues oftentimes indicate some other emotion from the meeting participant. The central controller could detect these verbal queues and use them to generate the meeting participants immediate reaction or emotion. For example, if a participant is listening to a presentation and does not agree with the content, they may make comments like, ‘I don’t agree, no way, that's absurd or some other short phrase, the central controller could pick this phrase up and use it to populate the meeting owner dashboard or other device recording/displaying their emotion.
Help that can be Provided by the Central Controller
In various embodiments, the central controller 110 may manage the type of connection made from a user device. The central controller may manage the connection with a view to achieving a stable connection while also giving the user the best experience possible. In various embodiments, if the central controller determines that a user device can only maintain a low bandwidth connection, the central controller may admit the user to a meeting as a virtual participant using only a low-bandwidth feed (such as an audio-only feed or a low-resolution video feed). On the other hand, if the user device can maintain a stable connection at high bandwidth, then the user may be admitted as a virtual participant using a high-bandwidth feed, such as via high-resolution video. In various embodiments, if a connection to a meeting participant is lost, the central controller may inform the meeting owner, the meeting presenter, and/or some other party. The central controller may attempt to re-establish a connection, perhaps a lower bandwidth connection. Once a connection is re-established, the central controller may again inform the meeting owner.
Central Controller Actions
In various embodiments, the central controller 110 may monitor a meeting or a room for problems, and may take corrective action. In various embodiments, the central controller 110 may take away the room if you have three people in an eight person room. It can then suggest other available rooms with the needed amenities and a simple 1 button acceptance or suggested change with notification to all participants. If there are technical issues in a room, the central controller 110 may take such actions as: Shut down room and turn off lights; Have video screens with shut down signal; Reschedule all meetings for other rooms; Notify facilities/IT personnel. If the room is not clean or has not been serviced, the central controller may arrange for food/beverage/trash removal. If a meeting has not been registered, the meeting may use a conference room on a “standby” status. That is, the room can be taken away (e.g., If the room is required by a meeting that was properly registered). If a person is absent from a meeting, or it is desirable to bring a particular person into a meeting, then the central controller may assist in locating the person. The central controller may take such actions as: Can ping them; Can break into a call or meeting room to contact the person; Can cause their chair to buzz or vibrate; Can buzz their headset; Can text them. In various embodiments, the central controller may perform a system self/pre-check prior to the meeting to make sure all devices are functioning (e.g., audio, video, Wi-Fi®, display, HVAC) and alert the responsible technical party and meeting organizer/owner. Meeting options to be provided if not resolved within 1 hour prior to the meeting.
Tagging the Presentation
Presentations contain valuable information but must be linked in a way to quickly and easily retrieve information at any point in time. The central controller could maintain access to all presentations and content along with the relevant tags. Tags may be used in various ways. These include: The main slide with the financials is tagged “financials”; Tag the slide which begins discussions around Project X; Tag slides as “optional” so they can be hidden when time is running low; Tag a presentation as “main microservices training deck”; Show who is a delegate for someone else; Tag for HR review later (and send meeting notes); Tag for legal review later (and send meeting notes). As an example, during an alignment meeting, a meeting owner is asked about the financials for project ABC which are not included in the current meeting presentation. The meeting owner asks the central controller to retrieve the financial information for project ABC. The central controller responds by sending the most recent financial slides for project ABC for display in the meeting.
Generating Meeting Notes/Minutes
While many meeting owners and meeting participants have the best of intentions when it comes to creating a set of meeting notes or minutes at the end of a meeting, all too often they are forgotten in the rush to get to the next meeting. A more efficient and automatic way to generate notes would allow for greater transparency into the output of the meeting. This is especially important for individuals who count on meeting notes to understand the action items that have been assigned to them. In various embodiments, meeting participants could dictate notes during or after the meeting. If a decision was made in a meeting, for example, the meeting owner could alert the room controller by getting its attention by saying a key word expression like “hey meeting vault” or “let the record reflect”, and then announcing that “a decision was made to fully fund the third phase of Project X.” The room controller would then send this audio recording to the central controller which would use speech to text software to generate a text note which is then stored in a record associated with the unique meeting identifier. Similar audio announcements by meeting participants throughout the meeting could then be assembled into a document and stored as part of that meeting record. Voice recognition and/or source identification (e.g., which device recorded the sound) can be utilized to identify each particular speaker and tag the notes/minutes with an identifier of the speaker. In various embodiments, the central controller listens to key phrases for diagnostic purposes such as items “you're on mute,” “can you repeat that,” “we lost you,” “who is on the call,” “can we take this offline,” “sorry I'm late . . . ” In various embodiments, cameras managed by the room controller could take images (or video) of walls during the meeting. A team that had done some brainstorming, for example, might have notes attached to the walls. In various embodiments, meeting notes could be appended to another set of meeting notes. In various embodiments, decisions from one meeting could be appended to decisions from another set of meeting notes.
Using Meeting Notes
While storing meeting notes is important, it may be desirable to make it easier for meeting participants to use those notes to enhance effectiveness and boost productivity. In various embodiments, the full corpus of all notes is stored at the central controller and fully searchable by keyword, unique meeting ID number, unique meeting owner ID, tags, etc. In various embodiments, less than the full corpus may be stored, and the corpus may be only partially searchable (e.g., some keywords may not be available for use in a search). In various embodiments, notes are sent to some portion of attendees, or everyone who attended or missed the meeting. In various embodiments, attendees are prompted for voting regarding the notes/minutes—e.g., attendees vote to indicate their approval that the notes/minutes represent a complete and/or accurate transcript of the meeting. In various embodiments, meeting notes are sent to people who expressed an interest in the notes (e.g., I work in legal and I want to see any set of notes that includes the words patent, trademark, or copyright). Various embodiments provide for automatic tracking of action items and notification to meeting participants upon resolution/escalation.
Meeting Assets and Batons
It may be desirable that meetings generate value for the business. The central controller 110 can provide transparency into whether meetings create value by recording the assets created during a meeting. Additionally, there may be task items generated during the meeting that need to be assigned to a person or team. These task items become a kind of “baton” which is handed from one person to another—across meetings, across time, and across the enterprise.
Recording Meeting Assets
Based upon the type of meeting, the central controller 110 can record and tag the asset created during the meeting. For example, in a decision meeting, the central controller could record that a decision was made and the reasoning. For innovation meetings, the central controller could record the ideas generated during the meeting.
Action Items
Some meetings generate action items, to-do items, or batons as an asset. The central controller 110 could record these actions items, the owner of these action items, and who created these action items. The central controller could alert employees of new action items. The central controller could provide these employees with a link to the meeting notes and presentation of the meeting that generated the action item, which would provide information and context to the action item.
Links Between Meetings
The central controller 110, based upon batons or other assets, could identify links between meetings. The central controller could identify duplicative, overlapping, or orphaned meetings. This can trigger actions based on meeting hierarchy—e.g., sub-meeting resolutions may trigger parent meetings to discuss/review resolutions/assets from sub-meetings.
Dormant Assets and Action Items
The central controller 110 could identify dormant assets or action items and flag them for review by their owners or schedule a new meeting.
Low Value Meetings
The central controller could flag meetings that produce few assets, result in dormant action items, or produce few assets relative to the expense of holding the meeting.
CEO (or Project Sponsor) Controls
Various embodiments provide a CEO (or other leader, or other authority, or other person) a chance to ask a challenge question in advance of a meeting based on the registered purpose of the meeting. For example, if the purpose of the meeting is to make a decision, the CEO can have an experienced and highly rated meeting facilitator ask a meeting owner (or some other attendee) exactly what they are trying to decide. The CEO may require that the meeting owner has to respond before the meeting, or deliver the output as soon as the meeting is done. In various embodiments, a CEO has the option to require an executive summary immediately after a meeting (e.g., within half an hour), on decision(s), assets generated, outcomes, and/or Other aspects of a meeting.
Request an Approval
In various embodiments, it may be desirable to obtain an approval, authorization, decision, vote, or any other kind of affirmation. It may be desirable to obtain such authorization during a meeting, as this may allow the meeting to proceed, for example, further agenda items that are contingent upon the approval. The approval may be required from someone who is not currently in the meeting. As such, it may be desirable to contact the potential approver. In various embodiments, the central controller 110 may set up a real-time video link from a meeting room to a potential approval. In various embodiments, the central controller 110 may email the decision maker with the data from the meeting to get an asynchronous decision. In various embodiments, the central controller 110 may message someone authorized to make a decision (or vote), e.g., if the main decision maker is not available.
Subject Matter Experts (Smes)
In various embodiments, it may be desirable to find someone with a particular expertise. The expert may be needed to provide input in a meeting, for example. For example, meeting participants may desire to find the closest available SME with an expertise of “Java”. Categories of expertise/SMEs may include the following: Coding; Supply chain/logistics; Finance; Marketing/Sales; Operations; Strategy; Value stream mapping; Quality/Lean; HR; IT Architecture; Customer Experience and Core Business knowledge; Meeting facilitator by meeting type (e.g., an SME whose expertise is facilitating Innovation Meetings); and/or Any other area of expertise.
Employee Handheld/Wearable Devices
In various embodiments, an employee device, such as a handheld or wearable device (e.g., a user device of table 900 or a peripheral device of table 1000), may assist an employee with various aspects of a meeting. In various embodiments, an employee device may: Show the employee the location of your next meeting; Show the employee who is running the meeting; Show the employee who the participants will be; Let the employee vote/rate during meetings; Connect the employee via chat/video with someone you need temporarily in a meeting; Display the meeting purpose; Display the slides of the deck; Take a photo of the whiteboard and send it to the central controller for that meeting ID number; Take a photo of stickies which the central Controller can OCR and add to meeting notes; and/or may I assist with any other action.
Network/Communications
In various embodiments, the central controller 110 could play a role in managing communication flow throughout the enterprise. If there are dropped connections from participants (e.g., from participant devices) provide immediate notification to the meeting owner for appropriate action. In various embodiments, a meeting owner could initiate a communication link between two ongoing meetings. The central controller could also automatically create a video link between two ongoing meetings that had agendas that were overlapping. For example, two meetings that identified Project X as a main theme of the meeting could be automatically connected by the central controller. In various embodiments, when network bandwidth is constrained, the central controller could turn off the video feeds of current virtual participants and switch them to audio only. If there is failed video/audio, the central controller may provide immediate notification to the meeting owner and other participants. Communication channels could also be terminated by the central controller. For example, a side channel of texting between two different meetings could be stopped while key decisions are being made in those meetings. During a meeting, the meeting owner could ask the central controller to be immediately connected to an SME who had expertise in data security.
Ratings and Coaching
A potentially important part of improving the performance of meetings (and employees) and bringing greater focus and purpose to work is to gather data from employees and then provide assistance in making improvements. One way to gather such data is by having participants provide ratings, such as polling all meeting participants in a 20-person meeting to ask whether or not the meeting has been going off track. Additionally, the central controller 110 could gather similar data via hardware in the room. For example, during that same 20-person meeting the central controller could review data received from chairs in the room which indicate that engagement levels are probably very low. These ratings by machine and human can be combined, building on each other. The ratings can then be used as a guide to improving performance or rewarding superior performance. For example, someone who was using a lot of jargon in presentations could be directed to a class on clear writing skills, or they could be paired with someone who has historically received excellent scores on presentation clarity to act as a mentor or coach. In this way, the performance of employees can be seamlessly identified and acted upon, improving performance levels that will translate into enhanced performance for the entire enterprise.
The ratings produced according to various embodiments can also be used to tag content stored at the central controller. For example, ratings of individual slides in a PowerPoint deck could be stored on each page of that deck so that if future presenters use that deck they have an idea of where the trouble spots might be. Edits could also be made to the deck, either by employees or by software at the central controller. For example, the central controller could collect and maintain all ratings for slides that deal with delivering financial information. Those financial slides with a high rating are made available to anyone needing to develop and deliver a financial presentation. This continual feedback mechanism provides a seamless way to continually improve the performance of the individual (person preparing the presentation) and the enterprise. Less time is spent on failed presentations and relearning which presentations are best at delivering information and making those available to anyone in the enterprise. Furthermore, in addition to providing the highly rated presentation, the actual video presentation could be made available for viewing and replication. If a presenter earned a high rating for delivering the financial presentation, the content and actual video output of the presentation could be made available to anyone in the enterprise for improvement opportunities. In various embodiments, ratings may be used to tag content. Thus, for example, content may become searchable by rating. Content may be tagged before, during, or after the meeting. Tags and ratings me until some of the feedback described with respect to
Feeling Thermometer
As a PowerPoint™ presentation is being presented, meeting participants could use a dial on their meeting participant device to indicate whether the material is clear. As a speaker is leading a discussion, meeting participants could use the same dial to indicate the level of engagement that they feel in the meeting. The output of such continuous rating capabilities could be provided in a visual form to the meeting owner, such as by providing that meeting owner with a video of the presentation with a score at the top right which summarizes the average engagement score as indicated by the participants.
Rating Participants
Participants can be rated by other participants on various meeting dimensions. These may include, contribution to the meeting, overall engagement and value as the role being represented. The central controller could collect all participant feedback data and make available to the participant, meeting owner and manager for coaching opportunities.
Dynamic Ratings and Coaching
During meetings, the central controller 110 could prompt presenters and participants for ratings. For example, the central controller could provide cues to the meeting owner or presenter to slow down or increase the speed of the meeting based upon time remaining. The central controller also could prompt individual participants to rate particular slides or parts of a presentation if it detects low levels of engagement based, for example, on eye tracking or chair accelerometers. Based upon ratings from prior meetings, the central controller could assign a “Meeting Coach” who can provide feedback at future instances of the meeting.
Signage in Room
Meetings often start with administrative tasks taking place and waste time getting to the true purpose of the meeting. Reinforcing relevant information at the start of a meeting can help to streamline the meeting time and set a positive tone in advance of the actual start. In various embodiments, signage (or some other room device) displays the meeting purpose (or says it out loud). In various embodiments, the central controller 110 knows the purpose of the meeting based on the meeting owner's input in the invitation. The central controller could display the purpose on all monitors in the meeting room and display devices accessing the meeting remotely. In various embodiments, signage (or some other room device) shows a meeting presentation. The central controller 110 can queue up the appropriate presentation based on the meeting owner input. As the meeting agenda is followed, each subsequent presentation can be queued as to not cause a delay in connecting a laptop and bringing up the presentation. In various embodiments, signage (or some other room device) shows people who have not yet arrived. Many meetings take enormous amounts of time taking attendance. The central controller can dynamically list those that have not joined the meeting either in person or virtually. Those attendees that have informed the meeting owner they will be late or not attend via the central controller can be displayed and also when their estimated arrival time will be. Those that actually attend can be sent to the meeting owner.
In various embodiments, signage (or some other room device) shows people who need to move to another meeting. Signage may give people their “connecting gates” for their next meeting. The central controller could provide proactive alerts to attendees requiring them to leave the meeting in order to make their next meeting on time. This can be displayed on the monitors or on personal devices. For example, if participant “A” needs to travel to another meeting and it takes 15 minutes of travel time, the central controller could provide a message to display that participant “A” needs to leave now in order to make the next meeting on time. Likewise, if participant “B” in the same meeting only needs 5 minutes of travel time, participant “B” could be altered 5 minutes prior to the start of the next meeting. In various embodiments, signage (or some other room device) shows people who are no longer required at this meeting. As meetings progress through the agenda, certain topics no longer require specific individuals in a meeting. Providing a visual indication of only those participants needed can help streamlining decisions and make everyone more productive. For example, if the first agenda topic takes 10 people in a meeting, but the second agenda item only needs 5 people, the central controller could notify those 5 they can now leave the meeting and display the message on the monitor and devices. In various embodiments, signage (or some other room device) shows a decision that was made last week which was relevant to the current meeting topic. Each agenda item/action item has a tag identified. As action items are resolved and decisions made, these can be displayed in advance of the meeting or throughout the tagged agenda items. For example, the central controller has access to all agenda items, action items and decisions and each has an associated tag. As the meeting progresses and topics in the agenda are covered, the central controller can display resolved action items and decisions relevant to the agenda topic and used in the discussions.
In various embodiments, the room knows what to say. Using meeting time to celebrate and communicate important information not directly related to the agenda items can be a way to reinforce key topics and focus on the people aspects of a company. In various embodiments, the room may display messages. The central controller can access HR information (birthdays, work anniversaries, promotions), third party external sites (traffic, weather alerts, local public safety information) and internal text or video messages from key leaders (CEOs, Project Sponsors, key executives). Example messages may pertain to: Promotions; Anniversaries; Birthdays; Company successes; Employee Recognition; CEO message; Traffic updates; “We just shipped the fifth plane with medical supplies”; “Did you know that . . . ?” In various embodiments, it may be desirable that messages take the right tone and be at the right time. The central controller knows each type of meeting taking place (informational, innovation, commitment and alignment). Based on the meeting type, the central controller displays meeting specific information on display devices and to attendees in advance. Innovation sessions should have lighter/more fun messages. On the other hand, commitment meetings might prevent all such messages. Learning meetings could feature pub quiz type messages. Alignment meetings may show messages indicating other people or groups that are coming into alignment. For example, a message may show four other teams in Atlanta are meeting about this same project (show a map of locations). In various embodiments, a message or view may be changed based on a particular tag (e.g., a participant may select a tag to show all microservices meetings). As another example, a participant may ask to see the top priorities for other orgs/ARTs/teams.
Audio/Video
In various embodiments, the central controller 110 may store audio and/or video of a meeting. The central controller may store the full audio and/or video of a meeting. In various embodiments, the central controller may store part of the audio or video of a meeting based on one or more factors. The central controller may store part of the audio or video of a meeting based on a request from participants (e.g., “please record the next two minutes while I describe my idea for improving collaboration”) (e.g., “please clip the last two minutes of discussion”). The central controller may record any time loud voices are detected. The central controller may record any time the word “decision” or “action item” is heard. The central controller may record a random portion of the meeting. In various embodiments, a presentation has built in triggers on certain slides that initiate recording until the meeting owner moves to the next slide.
Other Hardware Devices
Various devices may enable, enhance and/or complement a meeting experience.
Virtual Reality
In various embodiments, virtual reality goggles may be used in a meeting. These may provide a more complete sense of being in a meeting and interacting with those around the wearer. In various embodiments, these may obviate the need for a camera, screens, rooms—instead, the meeting controller handles it all.
Headsets
As more and more meetings are held virtually, a greater number of meeting participants are not physically present in a room. Those participants are connecting via phone, or more commonly via video meeting services such as Zoom® or WebEx®. In these situations, it is common for participants to be wearing headsets. Connected into the central controller 110, this could allow a headset to help sense more information from meeting participants. The headset could contain any of the following sensors and connect to them the central controller: accelerometer, thermometer, heating and/or cooling device, camera, chemical diffuser, paired Wi-Fi® ring or smart watch, galvanic skin response sensors, sweat sensors, metabolite sensors, force feedback device. In various embodiments, an accelerometer is used to detect head movements, such as:
-
- Detecting whether or not a meeting participant is currently nodding in agreement or shaking their head from side to side to indicate disagreement.
- Detecting head movements along a continuum so that the participant can indicate strong agreement, agreement, neutrality, disagreement, or strong disagreement based on the position of their head in an arc from left to right.
- Detecting whether a person is getting sleepy or bored by having their head leaned forward for a period of time.
- If a head turns abruptly, this could indicate a distraction and mute the microphone automatically. When a dog enters or someone not a part of the meeting (a child), oftentimes people turn their head quickly to give them attention.
- Detecting whether someone has been sitting for long periods to remind the wearer to take breaks and stand up.
- Head movements coupled with other physical movements detected by the camera could be interpreted by the central controller. For example, if a participant's head turns down and their hands cup their face, this may be a sign of frustration. Fidgeting with a headset might be a sign of fatigue.
- The central controller could interpret head movements and provide a visual overlay of these movements in video conferencing software. For instance, the central controller could interpret a head nod and overlay a “thumbs up” symbol. If the central controller detects an emotional reaction, it could overlay an emoji. These overlays could provide visual cues to meeting participants about the group's opinion at a given moment.
In various embodiments, a thermometer is used to measure the wearer's temperature and the ambient temperature of the room.
-
- The central controller could record the wearer's temperature to determine if the wearer is healthy by comparing current temperature to a baseline measurement.
- The central controller could determine if the individual is hot or cold and send a signal to environmental controls to change the temperature of the room.
- The central controller could use temperature to determine fatigue or hunger and send a signal to the wearer or the meeting owner to schedule breaks or order food.
In various embodiments, a headset could contain a heating and/or cooling device to signal useful information to the wearer by change temperature, such as whether they are next in line to speak, whether a prediction is accurate (“hotter/colder” guessing), proximity in a virtual setting to the end of level or “boss”, or signal time remaining or other countdown function. In various embodiments, the headset could have a camera that detects whether or not the user's mouth is moving and then check with virtual meeting technology to determine whether or not that user is currently muted. If they are currently muted, the headset could send a signal to unmute the user after a period of time (such as 10 seconds), or it could trigger the virtual meeting technology to output a warning that it appears the user is talking but that they are currently muted. In various embodiments, the headset could contain a chemical diffuser to produce a scent. This diffuser could counteract a smell in the room, use aromatherapy to calm an individual, evoke a particular memory or experience, or evoke a particular physical place or environment. In various embodiments, the headset could be paired with a Wi-Fi® ring/smart watch which would set off an alarm in the headset when the user's hand approached their face. This could allow presenters to avoid distracting an audience by touching their face, or it could be used to remind participants not to touch their face when flu season is in full swing. In various embodiments, the headset could contain galvanic skin response sensors, sweat sensors, and/or metabolite sensors. The central controller could record the galvanic skin response or the rate of sweat or metabolite generation to determine whether the wearer is healthy by comparing the current measurement to a baseline measurement. The central controller could then signal to the meeting owner whether the meeting should continue or be rescheduled.
Force Feedback
One or more devices could employ force feedback. This could include hardware associated with the device which causes the device to buzz when prompted. In various embodiments, the presentation controller could be used for the meeting owner to contact a meeting participant verbally. For example, a meeting owner may need to ask a question specific to another person without others hearing in the room. They could speak the question in the presentation controller and it could be heard by the meeting participant to respond. Also, they could use the same capability to request the meeting participant to engage in the discussion.
Microphones
Microphones may have various uses in meetings. Meetings are routinely interrupted by background sounds from remote meeting attendees causing a break in the meeting cadence and lost productivity. By using pre-recorded sounds that invoke a response by the central controller, the microphone could be put on mute automatically. For example, if your dog's bark is pre-recorded, the central controller could be listening for a bark and when recognized, the microphone is automatically put on mute. Similarly, if a doorbell or a cell phone ring tone is recognized, the microphone is put on mute automatically. In various embodiments, microphones should be muted automatically if they are outside the range of the meeting or the person is no longer visible on the video screen. Remote workers take quick breaks from meetings to take care of other needs. For example, a parent's child may start screaming and need immediate attention. If the meeting controller recognizes the meeting participant has moved from the video screen or several feet from their display device, mute the microphone automatically. Another example may be where someone leaves the meeting to visit the restroom. In various embodiments, a microphone is always listening (e.g., for a participant to speak). For participants that are on mute, once they begin to speak, the microphone detects this and automatically takes them off mute. For example, there are many occasions where meeting participants place themselves on mute or are placed on mute. Oftentimes, they do not remember to take themselves off of mute and it forces them to repeat themselves and delay the meeting.
Presentation Controllers and Remote Control Devices
Presentation controllers, remote control devices, clickers, and the like, may be useful in meetings. In various embodiments, hardware/software added to these devices can be used to increase their functionality, especially by allowing for direct communication with the central Controller 110 or room controller. In various embodiments, a presentation controller and/or remote control device may include a Wi-Fi® transmitter/receiver (or Bluetooth®). This may allow the device to communicate with the central controller, a room controller, participant device, smartphones, screens, chairs, etc. Wi-Fi® data can also be used in determining the position of the device. In various embodiments, a presentation controller and/or remote control device may include a GPS or other positioning device. This may allow the central controller to determine where the presentation clicker is and whether it is moving. In various embodiments, a presentation controller and/or remote control device may include one or more accelerometers. By knowing the position of the device in three dimensions, it can be determined where the pointer is pointing within a room, which can allow for the presenter to obtain and exchange information with participants or devices within the room. In various embodiments, a presentation controller and/or remote control device may include a microphone. This could pick up voice commands from the meeting owner directed to the central controller or meeting controller to perform certain actions, such as recording a decision made during a meeting. In various embodiments, a presentation controller and/or remote control device may include a speaker. The speaker may be used to convey alerts or messages to a presenter. For example, the presentation controller may alert the user when one or more audience members are not paying attention. As another example, a member of the audience may ask a question or otherwise speak, and the presenter may hear the audience member through the remote control device. In various embodiments, messages intended for the audience (e.g., messages originating from the central controller, from the CEO, or from some other party), may be output through the speaker. As will be appreciated, a speaker may be used for various other purposes.
In various embodiments, a presentation controller and/or remote control device may include a force feedback. This could include hardware associated with the device which causes the device to buzz when prompted. In various embodiments, a presentation controller and/or remote control device may include a display screen. This could be touch enabled, and could show maps, meeting participant information, slide thumbnails, countdown clocks, videos, etc. In various embodiments, meeting participants need to quickly move between virtual meeting breakout rooms. In order to easily navigate between rooms, the attendee could touch the meeting room they need to attend and the central controller automatically puts them in the meeting room for participation. Furthermore, if attendees need to be assigned to a meeting breakout room, the meeting room owner could easily touch the person's picture and drag the icon to the appropriate room. This can be done individually or in bulk by clicking on multiple picture icons and dragging to the appropriate room. In various embodiments, a presentation controller and/or remote control device may include lighting, such as one or more lights capable of displaying different colors and capable of flashing to get the attention of the presenter. Presentation controllers and remote control devices may have one or more capabilities enabled, according to various embodiments. Capabilities may include alerting/communicating with other devices.
Capabilities may include responding to or interacting with an object being pointed at. A presenter (or other person) may point a presentation controller at people to get information about their mood. A presenter may point a presentation controller at a statistic on a slide to pull up additional info. A presenter may point a presentation controller at a chart on a slide to email it to someone. In various embodiments, a clicker vibrates when it is pointed at someone who is waiting to ask a question. In various embodiments, a clicker vibrates when it is pointed at someone who is confused. In various embodiments, Augmented Reality (AR), such as through smart glasses, highlights different attendees in different colors to identify different votes, answers, moods, status, participation levels, etc. In various embodiments, AR may highlight an attendee if the clicker is pointed at the attendee. In various embodiments, a presentation controller and/or remote control device may change colors. In various embodiments, the device can turn red to reflect stress levels of participants. The device can automatically cue up a coaching video on a room display screen based on the current stress level of the room. In various embodiments, voice recognition capabilities may be useful (e.g., as a capability of a presentation controller and/or remote control device) in that they allow for the presenter to perform tasks without having to type messages and without breaking the flow of the presentation. In various embodiments, voiced instructions could be used for jumping to particular slides For example, the presenter could tell the device to jump ahead to “slide 17”. For example, the presenter could tell the device to jump ahead “five slides”. For example, the presenter could tell the device to jump ahead “to the slide with the financials”.
Managing a Meeting Break
Various embodiments may facilitate efficient meeting breaks. In various embodiments, a room screen shows everyone's current location. This may allow a meeting owner to more easily round up late returnees from a break. In various embodiments, people can text in a reason for being late to return. In various embodiments, participants could vote to extend the break. In various embodiments, the central controller could recommend a shorter break. In various embodiments, a countdown clock is sent to participant devices. In various embodiments, a countdown clock is sent to kitchen screens. In various embodiments, lights can go up during a break.
Playing Videos
In various embodiments, one or more videos may be played during a meeting, during a meeting break, prior to a meeting, or after a meeting. Videos may have a number of uses. During a meeting, videos may help to calm people down, instruct people, inspire people, get people excited, get people in a particular state of mind, etc. In various embodiments, a background image or video is used to encourage a particular mood for a meeting. For a commitment meeting, a calming image may be used, e.g., a beach. Music may also be chosen to influence the mood. For an innovation meeting, there may be upbeat music. There may also be a varying background. In various embodiments, the tempo of music (e.g., in a video) may be used to influence the mood. For example, music gets faster as you get closer to the end of the meeting. A video of the CEO may get participants thinking about purpose (e.g., a purpose for the meeting). The video may play two minutes before the meeting. An innovation session may start with a video of what problem the session is trying to solve. Financial stats scroll by so you can see where the company needs help. A program increment (PI) planning meeting (i.e., a standard meeting used as part of the SAFe/Agile development framework) may begin with a video explaining the purpose of the meeting as one to align employees to a common mission and vision. In various embodiments, any other meeting type may begin with a video explaining the purpose of the meeting.
In various embodiments, a background video may show customers being served. Meeting participants may get the feeling, “I want to be part of that”. In various embodiments, a cell phone (or other participant device) shows each participant a photo of a different customer. Virtual participants in a meeting may feel a kind of emotional distance to other participants as a result of the physical distance and/or separation. It may be desirable to break down the space between two physically distant people, i.e., to “connect them” more deeply. In various embodiments, participants may pick emojis to represent themselves. Emojis may represent a mood, a recent experience (e.g., emojis show the three cups of coffee that the participant has consumed), or some other aspect of the participant's life, or some other aspect of the participant. In various embodiments, some description (e.g., personal description) of a participant may appear on screen to better introduce the participant. For example, text underneath the participant's video feed may show for the participant: kids names, hobbies, recent business successes and/or a current position in a discussion of a commitment. Various embodiments may include a library of Subject Matter Expert videos in which these SMEs explain technical issues or answer questions related to their subject matter expertise. Videos may be stored, for example, in assets table 6000. SME videos may give people more confidence to make decisions because they have a deeper understanding of technical issues that may improve the decision quality. Videos may provide methodical injections of confidence builders. Videos may provide feedback from previous decisions. Videos may provide Agile software user story expertise. In various embodiments, an attendee has an opportunity to provide reasons that he is late for a virtual or physical meeting. In various embodiments, the meeting platform (e.g., Zoom) texts the attendee and gives him several options to choose from, such as: I will be five minutes late; Having trouble with my PC; I forgot, logging in now; I will not be there.
Enterprise Analytics
In various embodiments, analytics may help with recognizing patterns and making needed adjustments for efficiency and may contribute to the success of an enterprise. The central controller could collect some or all data related to meetings to train Artificial Intelligence (AI) modules related to individual and team performance, meeting materials and content, and meeting processes. Insights from these data could be made available to leadership or other interested parties through a dashboard or through ad hoc reports. An AI module may be trained utilizing meeting data to identify individual performance in leading and facilitating meetings, creating and delivering presentations, and contributing to meetings. Additionally, an AI module may be trained to optimize meeting size, staffing requirements, and the environment and physical layout of meetings. An AI module may be trained to identify meetings that are expensive, require large amounts of travel, or result in few assets generated. Some examples of meeting data that could be used as a training set for these and other AI modules include:
-
- Meeting size (number of participants, split out into physical and virtual)
- Meeting length (including allocations for travel time if appropriate)
- Number of meetings per day
- Meeting type
- Results accomplished
- Spawned action items or new meetings
- Time of day/week
- Purpose
- Presentation materials
- Participation rate
- Meetings linked to enterprise goals
- Tagged meetings and assets
- Cost of meeting
- Number of meeting invites forwarded for attendance
- Rating of meeting by participants
- Biometric data (for example, average level of engagement as determined via a combination of data from cameras in the room and motion data tracked by headsets)
- All other collected meeting information
Some examples of data related to meeting participants/owners that could be used as a training set for these and other AI modules include:
-
- Participant rating by meeting and aggregated over time
- Meeting owners rating by meeting and aggregated over time
- Ratings by seniority level. For example, do executives rate the meeting owner higher than their peers?
- Time spent in meetings over a period of time
- Number of meetings attended over time, by project and by enterprise goal
- Sustainability score by participant, owner, department and enterprise
- All other collected meeting information for participants and owners
- Hardware utilized
- Biometric data (for example, level of engagement of a particular meeting participant as determined via a combination of data from cameras in the room and motion data tracked by headsets).
In various embodiments, analytics may be used for generating reports, dashboards, overviews, analyses, or any other kind of summary, or any other view. Analytics may also be used for indexing, allowing for more efficient or more intelligent searches, or for any other purpose. In various embodiments, analyses may include:
-
- An overview of meeting assets generated.
- Reporting based on tags associated with meetings or presentation materials.
- Find the decision that was made on whether or not we are going into the German market; find the materials generated (e.g., the Kepner Tregoe method of decision analysis, the Porter's 5 forces analysis, the macroenvironment analysis, the Strengths, Weaknesses, Opportunities and Threats (SWOT)) that supported the decision to go into the German market based on asset tagging.
- Provide reporting for spikes in meetings. Provide reporting on the number of meetings on a certain day during a specific time period.
- Ratings. Provide reports on ratings for meeting, meeting types, assets and individuals (meeting owners and participants)
- System notices that the quality of meetings about Project X has decreased. This might then get a manager to audit the next meeting.
- Central controller has a database of pre/post meeting questions requiring rating by participants and selected by the meeting owner.
- Tables/chairs/layout (e.g., how many meeting rooms are “U” shaped, how many chairs does an average meeting room contain, etc.)/equipment type! equipment age
- Rooms (physical and virtual)
- Tend to go well—based on ratings by participants and meeting owners
- Facilities issues—based on ratings from meeting participants and meeting owners, including functioning equipment and cleanliness.
- Do people stay awake, engagement and mental and physical fitness based on biometric data collected during the meeting.
- Do actions (audio, warnings, lighting, AC changes, etc.) generate effects? Provide reporting based on environmental changes and the impact to meeting results and biometric data collected.
- All other collected meeting information for meeting rooms
The central controller 110 could collect all data related to headset communications and functions so that statistics and insights could be sent back to individuals and teams using a headset. The collected data could also be used to train Artificial Intelligence (AI) modules related to individual and team performance, meeting materials and content, meeting processes, business and social calls, in-game communications, athletic performance, and the like. Insights from these data could be made available to interested parties through a dashboard or through ad hoc reports. An AI module may be trained utilizing headset data to identify individual performance in leading and facilitating meetings, creating and delivering presentations, contributing to meetings, managing calls, athletic achievement, social achievement, and achieving success in a game. Additionally, an AI module may be trained to optimize meeting size, meeting effectiveness, and meeting communications. An AI module may be trained to identify meetings that are expensive, require large amounts of travel, or result in few assets generated.
In some embodiments, a CEO is interested in being more connected with those who work for her, and wants to be able to help a greater number of employees without spending all of her time attending meetings. The CEO could designate “office hours” which could be transmitted to a central controller, or saved into a data storage device of the headsets of all company employees. This would allow employees to connect seamlessly with the CEO, regardless of where they are or where the CEO is. The user's headset could include information via a video display of the headset (or via speakers) with information on whether or not the CEO was already in a call, and an indication of how many people might be currently in line to speak with her. The CEO could also use her headset to manage the priority of incoming calls, moving callers on hold up or down in priority. Users could also provide a short audio clip summarizing the reason for the call via a microphone of the user's headset which can be made available to the CEO via a speaker of her headset, enabling more effective prioritization of calls.
In some embodiments, users could subscribe to audio channels by tag, such as a software architect subscribing to all current audio feeds tagged with “architecture.”
Analytics regarding the performance of users on a call could also be provided to appropriate personnel at a company. Performance regarding call data could include speaking time, quality ratings from other participants, engagement levels of the user, etc. Input data could include call-related data, biometric inputs, user location, physical movements, volume and pitch of voice, direction of gaze, post-call 360s, tagging data, etc.
Predictive analytics could also be used to help user's avoid making mistakes or saying the wrong thing. For example, if a user's headset pulse rate sensor indicates that the user may be agitated while on a call, the processor of the headset may put the user on mute until his pulse rate drops to a level which indicates he is going to be more level-headed. Instead of automatically being muted, the user might be given a verbal warning by the headset or he might be connected via a sub-channel with a coach who can help guide him toward improved performance.
The user headset could also make predictions, either via the processor of the headset or in conjunction with the central controller, predicting when people are not at their best by reviewing camera, microphone, accelerometer, and other sensor data. Predictions by the headset could include whether or not the user is in good health, is tired, is drunk, or whether he might need a boost of caffeine.
Some examples of data that could be used as a training set for these and other AI modules include health data (e.g., blood pressure, pulse rate, pupil dilation, breathing rate), athletic performance data (e.g., velocity, location), emotional data, environmental sensor data (e.g., pollution levels, noise levels).
Security
Maintaining a secure meeting environment may be important to an enterprise. It may be important that only those meeting participants and owners that have privileges to a meeting can actually join and participate. The central controller should maintain information about each person that is used as an additional layer of meeting security. Dimensions that can be used to authenticate a meeting owner and/or participant include:
-
- Facial Recognition
- Voiceprint
Various embodiments include a mouse that shows me that my opponent is someone that I have played against before. The mouse may also show prior moves or strategies of my opponent. Similar to how sports teams watch game videos to learn the playing style and strategies of other teams, the same approach may be used with peripherals. For example, Player 1 is invited to play a game with Player 2 or initiates play with Player 2 using a peripheral (e.g., mouse, keyboard). Player 1 requests through the peripheral 3800 to the network port 9410 the previous opening game moves or typical movements from Player 2's processor 9405 and storage device 9445. Player 1 receives the stored game information from Player 2 through the house controller 6305a-b and central controller 110 to her device for display on screen 3815. Examples of the information Player 1 receives on the peripheral from Player 2 at the start of the game is that they frequently move to the right in the map sequence, hide behind a building in a combat game, during a chess match make the move 1.e4 75% of the time. This information may be displayed on Player 1's screen 3815 in text form or image form (e.g., chess board showing the typical moves). In addition, Player 1 may receive the complete statistics of Player 2 for a game being played such as the number of lives lost, the type and number of weapons used, the number of chess moves before a win or loss, the amount of time spent playing the game over some time period (e.g., 3 hours of Fortnite® during the last 7 days). All of the information allows Player 1 to gain more insight to Player 2's strategy, strengths and weaknesses for the game being played.
Biometrics Used to Make Game Recommendations
In various embodiments, player biometric and game data is used to more closely match different games for each player. Mouse 3800 and AI accelerator 9460 for Player 1 may collect data over time from sensor 9430 and input device 9420 for use in making game recommendations. For example, Player 1 may play war type games and sensor 9430 detects an elevated heart rate and excessive sweating while at the same time hit rate of weapons decreases and movement of the avatar slows. The AI accelerator 9460 may determine that war games cause Player 1 frustration and do not promote their unique gaming skills. The processor 9405 takes the information collected from storage device 9445 and AI accelerator 9460 and communicates to house controller 6305a-b, central controller 110, and/or to various game manufactures. The stored information of Player 1 is used to provide recommendations for games that are less intense that may not cause the heart rate to increase, use less skill and accuracy in using weapons and make the player less frustrated. These game recommendations are sent through the network port 9410 or input device 9420 to the processor 9405 for display on output device 9425. Player 1 may want to switch or purchase the recommended game as a way to achieve a more satisfying experience.
Various embodiments include an adaptive mouse for visual impairment. There may be situations where a visually impaired person may need to have the mouse 3800 to adjust information delivery from output device 9425 to accommodate the impairment. For example, the user may indicate through mouse 3800 that he is visually impaired through input device 9420, and information about the impairment may then be stored in storage device 9445. When game play occurs, images and text that would typically display on screen 3815 may be enlarged based on the visually impaired information stored in 9445. In addition, text images that are typically displayed for non-visually impaired users may now also be audio generated and heard through speaker 3821 (e.g., a message displayed on screen 3815 reading ‘Hey, this is Jim. Do you want to listen to my podcast?’ may now be heard through speaker 3821 as well). Colors that may typically appear on lights 3818 for non-visually impaired people may now cause the mouse 3800, through output device 9425, to vibrate (e.g., a green light generates 1 vibration, a yellow light generates 2 vibrations, and red light generates 3 vibrations).
Customized Modes for Mouse/Keyboard
A visually or hearing impaired individual may need to enable, disable, modify default settings and store the information in a peripheral. This information may be used by gamers, streamers and other players to deliver and communicate information. For example, user 1 may be hearing impaired, with 50% hearing loss. Using mouse 3800, the user may indicate through input device 9420 that they have lost 50% of their hearing. This information is collected by the processor 9405 and stored in storage device 9445. When the user plays a game, listens to a streamer or podcast, the device may amplify the sound 100% through output device 9425 and speaker 3821 to assist the user in hearing better. In addition, words that may typically be heard in a game, podcast or by a streamer are now displayed on screen 9435 as an alternative form of communication to the user. Likewise, visually impaired individuals with stored data in storage device 9445 (e.g., 75% vision loss) may require that information delivered through screen 9435 is now magnified (e.g., from 100% to 125%) for easier viewing or delivered audibly through output device 9425 and speaker 3821.
Various embodiments include the ability to change the priority settings of the mouse, e.g., so that you can go from work settings to game settings. There may be situations where a peripheral (e.g., mouse) is used for both business and pleasure. A user at work may want fewer visual and audio signals to be sent to them as this can interrupt co-workers. However, when a peripheral is used at home to play a game, the user may want the full features of the visual and audio capabilities. The user may store the work mode preferences in storage device 9445 (e.g., limit audio output on speaker 3821 to only critical alerts, turn off visual alerts on screen 9435) or pleasure mode preferences (e.g., amplified audio of 125% output on speaker 3821, all visual alerts on screen 9435) through input device 9420. For example, at work, device 3800 may be placed into work mode by the user through input device 9420, indicating that the user is in work mode and work mode preferences stored in 9445 are utilized. When normal priority messages sent from the children are received through input device 9420 or network port 9410, these messages may not get displayed on screen 3815 or delivered through speaker 3821 since the preference does not allow this. However, if a critical alert message is received from the user's spouse, the mouse 3800 using work mode preferences now displays the message on screen 3815 and the message is played audibly through speaker 3821. Later in the evening, the user may play a game and indicate through mouse 3800 that they are in game mode and using game setting preferences stored in storage device 9445. When messages, alerts, game sounds and images are sent to the peripheral through input device 9420, these may be displayed on screen 3815 and heard through speaker 3821 since the game mode preferences may not disable these functions.
Authentication
In various embodiments, a user's pattern of interaction with a peripheral device may serve as a presumed unique identifier or authenticator of the user. In such embodiments, it may be assumed that different users interact differently with a peripheral device, and such differences can be discerned using an algorithm. For example, a user's interaction pattern with a peripheral device may be quantified in terms of one or more features. In a first example, when a user types the word “the” on a keyboard, the ratio of (1) the elapsed time between typing the “t” and the “h”; to (2) the elapsed time between typing the “h” and the “e”, may serve as one feature. In another example, the absolute elapsed time between typing the “h” and the “e” may be another feature. In another example, the amount of pressure a user uses on a key (or on a button) may be another feature. In fact, there may exist a separate feature for each key or button. In another example, the top speed at which a user moves a mouse may be a feature. In another example, the average speed at which a user moves a mouse during the course of a motion may be a feature. In another example, the pressure a user exerts on a mouse button when the user is not clicking the button may be a feature.
For any given user, values for the aforementioned features, a subset thereof, or any other features, may be recorded and/or calculated based on historical usage data (e.g., based on three hours of usage).
When it is desirable to verify the identity of a user, or otherwise authenticate the user, a new sample of usage data may be obtained from the user. For example, the user may be asked to type a paragraph, or to perform a series of tasks on a website or app that involve clicking and moving a mouse. Usage features may be calculated from the newly obtained usage data. The new values of the usage features may be compared to the values of the usage features obtained from the user's historical usage data. If the newly obtained values match the historical values (e.g., the sum of the absolute values of the differences is less than a predetermined amount), then the user may be considered verified.
In various embodiments, a classification algorithm may be used (e.g., a decision tree), to classify an unknown user by deciding which known user's data is most closely matched by data newly obtained from the unknown user. As will be appreciated, various embodiments contemplate other ways in which the usage patterns of a peripheral device by a user may be used to authenticate the user.
In various embodiments, data passively obtained from users, such as via sensors (e.g., heart rate sensors) may also be used to create features, and/or to authenticate a user. In various embodiments, sensor data may be used in combination with usage data.
In various embodiments, usage patterns, features obtained from usage patterns, sensor data, and/or features obtained from sensor data may serve as a biometric.
In various embodiments, a biometric may serve as a way to identify or authenticate a user. In various embodiments, biometric may serve as a basis for responding to the user, adapting to the user, enhancing the user experience, or otherwise making a customization for the user. For example, a usage pattern may correlate to a skill level in a game, and the central controller may utilize the inferred skill level to adjust the difficulty of a game.
In various embodiments, certain activities may have legality, eligibility, regulatory, or other rules that vary from location to location. For example, gambling may be legal in one jurisdiction, but not in another jurisdiction. In various embodiments, a peripheral device may be used to authenticate a user's location, or some other aspect of the user, in order to comply with any applicable laws or regulations.
In various embodiments, a peripheral device includes a GPS sensor, a positioning sensor, or any other location sensor or determinant. When a user is contemplating a regulated activity, the peripheral device may transmit to the central controller, or to some other authority, an indication of the user's location. The user may then be granted permission to participate in the regulated activity based on whether or not the activity is permitted in the user's location.
In various embodiments, a peripheral device may be used as part of a process of multi-factor authentication. A user may initially be associated with a particular peripheral device (e.g., with a trusted peripheral device). For example, the user registers a trusted peripheral device in association with his name. Presumably, this peripheral device would henceforth be in the possession of the user. In various embodiments, when a user is attempting to authenticate himself for some reason, a temporary code, personal identification number (PIN), or the like may be sent to the same peripheral device. The user may then key in the same code (e.g., on some other device, such as on a personal computer) as part of the authentication process.
In various embodiments, as part of a multi-factor authentication process, a user is prompted to use a peripheral device. The user's unique pattern of usage may then serve as a confirmation of the user's identity.
The biometric data from the devices could be used for validating survey responses and embedded survey experiments. For example, whether a person actually took the survey and whether the individuals were confused or frustrated by particular survey questions. Additionally, the object of the survey could be to measure an individual's biometric responses when asked particular questions.
Online advertisers often pay per click or impression. These revenue systems are often spoofed by bots or other means. The devices according to various embodiments could be used to authenticate “true clicks” or “true impressions” by verifying that an actual person clicked or viewed the ad. In some embodiments, peripheral device (e.g., mouse, keyboard, headset) movements generated by a user may be transmitted to central controller 110 for correlation of their timing with any clicks on advertising. Clicks that are not associated with any peripheral movement would be deemed as illegitimate clicks. In other embodiments, cameras or sensors (e.g., motion sensors, microphones) may similarly send information to central controller 110 as corroborating data regarding verification of user mouse clicks on advertisem*nts.
Many websites prohibit online reviews, posts, or comments which are posted by bots or other automated means. The devices according to various embodiments could be used to authenticate that online reviews, posts, or comments were made by an actual individual.
In various embodiments, peripheral devices may serve as a first or second check that a live user is providing information. Sensors built into peripheral devices, and vital signs or biometrics read from peripheral devices, may be used to verify that a live user is providing some information or instruction, such as a password, credit card number, review, post, game input, etc.
Advertisers often have difficulty in distinguishing between different users on shared devices and tracking individuals across multiple devices. The devices according to various embodiments could help advertisers disambiguate and track users, either because individuals sign into their devices, or because a user's “fist,” or characteristic patterns of inputs could allow the central controller to identify particular individuals using a device or an individual across several devices.
Turning now to
The depicted biometric data is intended for illustrative purposes, and does not necessarily depict actual data read from an actual human being.
In
In various embodiments, biometric data is used to establish features and/or combinations of features that can be uniquely linked or tied to an individual. The following discussion represents some methods of extracting and using features according to some embodiments. However, it will be appreciated that other methods of extracting and features could be used and are contemplated by various embodiments herein.
With respect to facial measurements 8904, raw data may include an image of a face, such as an image captured by a video camera. The image may be processed (e.g., using edge detection, peak detection, etc.) to determine the location of “landmarks”, such as the centers of eyes, the corners of lips, the tips of cheekbones, the bridge of a nose, etc. Distances may then be determined between various combinations of landmarks (e.g., between nearby landmarks). At 8904 are depicted various exemplary distances, including a distance between the centers of the eyes 8920a, a distance from the bridge of the nose to the tip of the nose 8920b, a distance from a first corner of the nose to a first cheekbone 8920c, and a distance from a second corner of the nose to a second cheekbone 8920d. In various embodiments, any suitable landmarks may be used, and any suitable distances may be used.
In various embodiments, to allow for different ranges from the subject at which an image may be captured, distances between landmarks may be normalized, such as by dividing all distances between landmarks by a particular distance (e.g., by the distance between the centers of the eyes 8920a). In such cases, all distances are effectively expressed as multiples of the particular distance (e.g., as multiples of distance 8920a). Normalized distances may then be used as the “X” input (i.e., a vector of inputs) to a classification algorithm, or other AI algorithm, or other algorithm.
Whereas some biometric markers remain relatively constant (e.g., fingerprints), EEG data can change in response to a user's actions or to stimuli experienced.
Methods for classifying individuals based on EEG data are discussed in the paper “Exploring EEG based Authentication for Imaginary and Nonimaginary tasks using Power Spectral Density Method”, Tze Zhi Chin et al 2019 IOP Conf. Ser.: Mater. Sci. Eng. 557 012031, the entirety of which is incorporated herein for all purposes.
With respect to EEG data 8906, raw data may be determined from electrodes placed at two or more points on a user's head. In various embodiments, one of the electrodes is placed proximate to the motor cortex. In the “10-20 system”, the electrode may correspond to the “C4” electrode.
A user is asked to imagine performing a task repeatedly, such as opening and closing his hand once every second for sixty seconds, where the seconds are marked with an audible tone (e.g., with a metronome). In various embodiments, any suitable task may be performed. In various embodiments, the task need not be repetitive.
As the user performs the imaginary task, a voltage differential is measured between two electrodes. An amplifier may be used to amplify the voltage differential. The voltage differential may be recorded as a function of time (e.g., using multiple samples; e.g., with a sample rate of 1024 Hz), thereby generating a time series waveform. In fact, voltage differentials may be recorded across multiple pairs of electrodes, thereby generating multiple waveforms (i.e., one waveform for each pair of electrodes). Graphic 8906 shows exemplary waveforms from 16 different pairs of electrodes.
The raw waveform(s) may be filtered to preserve only certain ranges of frequencies. Commonly recognized frequency bands with respect to EEG data include delta, theta, alpha, beta, and gamma frequency bands. In various embodiments, a bandpass filter (e.g., a Butterworth bandpass filter) is used to preserve the beta frequency band (from 13 to 30 Hz).
The spectral density of the filtered waveform is then estimated using Welch's method. Welch's method includes segmenting the filtered time-series into overlapping 1-second segments, applying a windowing function at each segment, transforming the results using a discrete Fourier transform, and computing the squared magnitudes of the transformed results. The squared magnitudes are then averaged across all the results (i.e., all the segments). At the end is a set of frequency “bins” and associated power measurements for each bin, ie., a power spectral density. In various embodiments, other methods of computing a power spectral density may be used.
Features are then extracted from the power spectral density. In some embodiments, features include each of the: mean (i.e., the mean power magnitude across all the frequency bins), median, mode, variance, standard deviation, minimum and maximum.
In some embodiments, features are the individual power levels for the respective frequency bins.
Once extracted, features then serve as an input to a K-nearest neighbor classification algorithm. In various embodiments where authentication of a user is desired, the feature vector (i.e., the “X” vector) must fall within a predetermined “distance” of the reference vector (i.e., the “Y” vector) for the user in order to make an affirmative authentication. In various embodiments, any other suitable algorithm may be used.
In various embodiments, rather than asking a user to perform a particular task, the headset or central controller 110 may observe a task that the user is performing and/or a stimuli that the user is experiencing. For example, the headset may observe (e.g., via a forward facing camera in the headset) that a user is looking at a particular piece of machinery. A waveform may be determined at the time of the task or stimuli, and this waveform may be compared to a reference waveform generated under similar conditions (e.g., when the user was performing a similar task, or experiencing similar stimuli).
In various embodiments, a classification algorithm (or other algorithm), seeks to determine not whether a subject corresponds to a particular individual, but rather whether a subject's mental state corresponds to a particular mental state (e.g., “alert”, “drowsy”, “drunk”, etc.). For example, it may be desirable to assess whether an individual is in an alert mental state prior to entering a room containing dangerous equipment.
The process for classifying a mental state may proceed along similar lines, but where a reference signal is not necessarily derived from the subject being tested. Rather, a reference signal for an “alert” mental state may come from a different individual, or may represent an “average” signal from various individuals each of whom is known to be in an “alert” mental state.
Various embodiments seek to classify a mental state of “recognition” or “familiarity”, in contrast to such states as “novelty” or “confusion”. In such embodiments, a user may see or be shown a stimulus (such as a piece of lab equipment). After having experienced the stimulus (e.g., seen the object), the user's mental state may be classified as one of “recognition”, or “novelty”. It may thereby be determined whether or not the user has had prior experience with the stimulus (e.g., whether the user has seen the object before). In authentication embodiments, a user may be shown an object which the authentic user will likely recognize, but which an imposter likely will not. Then, based on the user's classified mental state, the user's identity may be confirmed, or not.
With respect to iris and/or retinal data 8908, raw data may include an image of an iris or retina. The captured image may be divided into sectors. These sectors may be of standardized size and shape (e.g., a sector encompasses 45 degrees of arc and one third the radius of the image of interest, e.g., one third the radius of the iris). Exemplary sectors are depicted at 8924a, 8924b, and 8924c. Various embodiments contemplate, however, that more or fewer sectors could be used, and differently shaped sectors could be used.
For each sector, an overall grayscale metric may be determined. For example, a sector that is very light in color receives a metric of 0, while a sector that is very dark in color receives a metric of 1. In various embodiments, the grayscale metric may be determined by averaging the color across the whole sector (e.g., by taking an average value of all the constituent pixels falling within a sector).
In various embodiments, to allow for different illuminations at which an image might be captured, grayscale values for sectors may be normalized. For example, the brightest sector receives a value of 0, the darkest sector receives a value of 1, and grayscale values for other sectors are scaled so that their proportionate distances from the values of the brightest and darkest sectors remain the same.
Once sectors receive grayscale values, such values may then be used as the “X” input to a classification algorithm, etc.
With respect to voice data 8910, raw data may include pressure data sampled from a microphone (e.g., at 48 kHz), thereby generating the depicted time series waveform. The waveform may be transformed into the frequency domain, such as via a Fourier transform, thereby generating a frequency spectrum 8912. A peak detection algorithm may then be used to find peak frequencies (.e., frequencies representing local maxima in the frequency spectrum). A predetermined number of the most strongly represented peak frequencies may be selected. For example, the 10 strongest peak frequencies may be selected. These may be sorted by amplitude, and then used as the “X” input to a classification algorithm, etc.
In various embodiments, when peak frequencies are detected, only fundamental frequencies are considered, and harmonic frequencies are eliminated from consideration. For example, if there are peaks detected at 440 Hz and at 880 Hz, the peak at 880 Hz may be eliminated from consideration.
In various embodiments, rather than detecting peak frequencies, amplitudes a1, a2, a3, etc. may be recorded for a set of predetermined frequencies f1, f2, f3, etc. The amplitudes may then be used as the “X” input to a classification algorithm, etc.
With respect to fingerprint data 8914, raw data may include an image of a fingerprint. The captured image may be divided into regions. These regions may be of standardized size and shape (e.g., a region is a square 0.5 millimeters on a side). Exemplary regions are depicted at 8940a, 8940b, and 8940c. For each region, an overall grayscale metric may be determined. And analysis may proceed as described above with respect to iris/retinal data 8908.
With respect to heart waveforms 8916, raw data may include, for example, an ECG waveform. A typical ECG waveform may include five standard segments, labeled P, Q, R, S, and T. Each has a biological significance (e.g., the P segment corresponds to contraction of the atrium). Each segment may have an associated duration and an associated amplitude. For example, the P segment may last 0.11 seconds and have an amplitude of 0.3 mV. In addition, since not all segments are contiguous, additional segments may be defined with combinations of letters (e.g., where ST represents the interval from the end of S to the beginning of T).
In various embodiments, the durations and amplitudes of the different standard segments may serve as features. Additionally, durations for the additional segments (e.g., for ST) may also serve as features. These features may then be used as the “X” input to a classification algorithm, etc.
Gestures
In various embodiments, it may be desirable to identify someone based on their gestures, such as by their head motions when they are wearing a headset. As such, it may be desirable to extract and/or utilize certain features of detected gestures as input to a machine learning model, algorithm, AI algorithm, and/or as input to any other algorithm. For example, the output of such an algorithm may be an identification of an individual (e.g., from among multiple possible individuals), or the closeness of fit between an input gesture and a reference gesture (e.g., an indication of confidence that a person is who he says he is). In various embodiments, gestures may be recorded and/or detected by means of motion sensors, accelerometers (e.g., accelerometers 4070a and 4070b), or the like.
In various embodiments, features of gestures may include one or more of: the distance moved in one direction (e.g., the distance of a head motion from top to bottom when someone is nodding his head); the number of reversals in direction per unit time (e.g., the speed with which someone shakes their head or nods their head); the maximum upward distance moved when compared to a neutral position (e.g., how far does someone lift their head during a head nod); the maximum downward distance moved when compared to a neutral position; the most commonly assumed position (e.g., how does someone commonly hold their head, whether it be straight, tilted slightly to the right, tilted forward, etc.); the amount of head motion associated with speaking; the amount of head motion associated with drinking; the amount of head motion exhibited when responding to a voice from behind the user (e.g., does the user turn his head to face the other person); and/or any other suitable features.
Productivity/Performance Enhancements
In various embodiments, a peripheral device measures the performance of an associated user device (e.g., the speed, processor load, or other performance characteristics). The peripheral device may determine such performance in various ways. In some embodiments, a user device informs the peripheral device of the current processor load, the current availability for inputs, or some other measure of performance. In various embodiments, a peripheral device may sense how frequently it is being polled by the user device for user inputs at the peripheral device, how frequently the user device is accepting messages from the peripheral device, how frequently the user device is sending signals back to the peripheral device, or any other indication of the performance of the user device. In various embodiments, a peripheral device may indirectly infer the performance of a user device. For example, if a user is repeating the same input motions at a peripheral device, it may be inferred that the user device has been slow to register such motions. For instance, a user may be trying to click a tab on a web browser, however the tab may be very slow to come up on the user device because the user device is occupied with some other process or is otherwise exhibiting poor performance characteristics. A peripheral device may infer poor performance of a user device if the user is making repetitive inputs or motions, if the user is employing exaggerated motions, if the user is waiting an unusually long time between motions (e.g., the user is waiting for the user device to register an earlier motion before making a new motion), if the user's rate of typing has slowed down, or if the pattern of user inputs at the peripheral has changed in any other fashion.
In various embodiments, by providing insight into the performance of a user device, a peripheral device may assist in the pricing of a warranty or other service contract for the user device. For example, if the user device is exhibiting poor performance, a warranty may be priced more expensively than if the user device is exhibiting good performance characteristics. In various embodiments, peripheral devices may be used to suggest to a user that the user obtain professional assistance with improving the performance of the user device. In various embodiments, a peripheral device may trigger an application or other program that is designed to increase performance of a user device (e.g., a memory defragmenter).
In various embodiments, a peripheral device may adjust the data it sends to a user device based on the performance of the user device. For example, if the user device is exhibiting poor performance characteristics, then the peripheral device may limit data sent to the user device to only high-priority data. For example, the peripheral device may prioritize data on basic motions or other user inputs, but may refrain from sending data about the user's vital signs, ambient conditions, voice messages created by the user, or other types of data deemed to be of lesser priority. If performance characteristics of a user device later improve, then the peripheral device may send data or signals that had been previously held back.
In various embodiments, a peripheral device may be the property of a company, or other organization. In many organizations, peripheral devices are assigned to individuals. For example, an individual has his or her own desk, and peripheral devices reside more or less permanently at the desk. However, in situations where individuals do not work full-time, are not in the office full-time, are not at their desk frequently, or in other situations, a peripheral device may remain unused for a significant period of time.
In various embodiments, a company or organization may increase the utilization of peripheral devices by allowing such devices to be shared among different users. For example, users with complementary schedules (e.g., one user works mornings, and the other user works afternoons) could share the same peripheral device. This would allow a company or other organization to get by with fewer peripheral devices, or to permit greater usage of expensive peripheral devices.
In various embodiments, users may schedule time to use peripheral devices. When it is a given user's turn to use a device, the user's name, initials, or other identifying information may appear on the peripheral. In various embodiments, when it is a user's turn with a peripheral, only that user may activate the peripheral, such as with a password or a biometric.
In various embodiments, a peripheral may track its own usage. The peripheral may discover patterns of usage. For example, the peripheral may discover that it is never used on Wednesdays. Based on the pattern of usage, the peripheral may advertise its availability during times when it would otherwise be idle. For example, a peripheral may advertise its availability every Wednesday. A user in need of a peripheral during such idle times may sign up to use the peripheral at these times. Alternatively, a scheduler (e.g., the central controller) may assign peripherals to different users who are known to be in need at such times.
In various embodiments, a peripheral may provide instructions to a user as to where to leave the peripheral when a user is done with it (e.g., leave it on the conference table of the marketing department), so that the next assigned user can begin using the peripheral.
In various embodiments, a peripheral may be configurable to communicate with different user devices. A switch or other input device on the peripheral may allow the user to associate the peripheral with different user devices. For example, a user may place a switch on a keyboard in one position, after which the keyboard will direct keystrokes to a personal computer; the user may place the switch on the keyboard in another position, after which the keyboard will direct keystrokes to a tablet computer. The switch may be physical. In various embodiments, the switch is virtual, such as a picture of a switch on a touch screen.
In various embodiments, a peripheral device saves one or more inputs to the device.
Such inputs may include key presses, button presses, wheel scrolls, motions, touches on a touchpad, turns of a trackball, or any other inputs. In various embodiments, a peripheral device may save sensor readings. Saved inputs may include timestamps or other metadata. Such data may allow the inputs to be placed in chronological order.
In various embodiments, a user may search through old inputs to a peripheral device. For example, a user may enter a sequence of inputs which he wishes to find from among historical inputs. In the case of a keyboard, a user may wish to search for a sequence of keystrokes, such as a word or a phrase. The user may key in such keystrokes into the keyboard. The keyboard may then display to the user (e.g., via a display screen) any matches to the user's search. The keyboard may display context, such as keystrokes that were entered before and after the particular keystrokes that are the subject of the search. In various embodiments, the keyboard may present search results in another fashion, such as by transmitting the results to a separate display device, by saving the results to a memory (e.g., to an attached USB thumb drive), or in any other fashion.
Where a user is able to search for inputs on a peripheral device, the search may effectively span across multiple applications and even across virtualized OS partitions. In other words, a single search may locate inputs that were directed to different applications, and even two different OS partitions.
In various embodiments, a peripheral device may track usage statistics. Such statistics may include number of buttons pressed, number of times a particular button was pressed, number of times a particular key was pressed, the distance a peripheral was moved, the number of different sessions during which a peripheral was used, the number of times a headset was put on, or any other usage statistic. Usage statistics may also be tracked by another device, such as a user device linked to a tracked peripheral device.
In various embodiments, an app may allow a user to view usage statistics. The app may communicate directly with a peripheral device, such as for the purposes of uploading usage statistics. In various embodiments, the app obtains usage statistics from the central controller, which in turn receives such statistics from a tracked peripheral device (e.g., directly, e.g., indirectly).
In various embodiments, a peripheral may track patterns of usage and associate such patterns with either productive or non-productive work. Examples of non-productive work may include playing video games, surfing the web, arranging photos, or any other activities. Initially, a peripheral may receive information about an app or program with which a user is interacting. Based on the type of app, the peripheral may classify whether such activity is productive or not. In various embodiments, a user may classify different apps or activities as productive or not, and may indicate such classifications to a peripheral device.
The peripheral device may then learn to recognize patterns of inputs associated with a productive activity, versus those associated with a non-productive activity. For example, in a game of solitaire, a peripheral device may learn to recognize the repetitive motions of dragging cards to different locations. A peripheral device may later classify a user's pattern of inputs without direct knowledge of the app to which such inputs are directed.
In various embodiments, if a peripheral device determines that a user is engaged in non-productive activities, the peripheral device may take one or more remedial actions. Actions may include: shutting off, reducing functionality, temporarily shutting off, alerting a user that he is engaged in a non-productive activity, or any other remedial action.
In various embodiments, video footage may be captured of a user typing. Video footage may be captured, for example, by a camera, such as by a camera peripheral device. The video footage may be used for improving auto suggestion, auto complete, computer generated text, or for any other tasks. Context clues from the video (e.g., derived from the video) may include speed, typing mistakes, deleted words, text that gets modified, and any other clues. These contextual clues or features may be used in combination with surrounding text in order to make new predictions (e.g., in order to predict the remaining words in a sentence). In various embodiments, contextual clues may be used for sentiment analysis. For example, if a user is typing in a very animated way, then a happy or excited sentiment may be inferred. In various embodiments, contextual clues are used in combination with the inferred meaning of the text in order to estimate a sentiment.
In various embodiments, a peripheral device may correct or otherwise alter user inputs. The peripheral device may make such corrections or alterations prior to transmitting the inputs to a user device. In various embodiments, a keyboard may correct typing inaccuracies before displaying, transmitting, or otherwise handling user inputs. For example, a user might type ‘teh’ and the keyboard outputs ‘the’ to the associated user device (e.g., computer).
In various embodiments, a peripheral device may make automatic corrections based on both a particular input (e.g., an erroneous input), and a user behavior (e.g., typing style). For example, one type of error may be common with a particular typing style. Thus, for example, if an error is detected, then the error may be corrected if it is known that the user employs that typing style. Identified errors or mistakes may be handled differently depending on whether the typing style is, for example, ‘touch’, ‘chop-stick’, ‘looking at’, ‘anthropometry’, etc.
In various embodiments, certain mistakes or errors may be more common with certain types of keyboards. For example, the relative key spacing on certain types of keyboards may make it more common for certain keys to be inadvertently interchanged. In various embodiments, an identified error may be corrected one way if a user has one type of keyboard, or another way if the user has another type of keyboard.
In various embodiments, a user's game performance, chess performance, productivity, etc., is predicted based on initial movements, initial activities, initial performances, and/or environmental queues. For example, the central controller may predict a user's ultimate score in a game based on his first five minutes of play. As another example, the central controller may predict a user's performance based on the ambient noise level. If it is predicted that the user will achieve a high performance, then the user may be encouraged to continue. However, if it is predicted that the user will achieve a poor performance, then the user may be advised to halt his activities (e.g., halt his game playing), seek to change his environment (e.g., move to a quieter place), or to take some other action (e.g., to take a deep breath).
In various embodiments, tracking performance on a game (or other task, e.g., typing speed) may be used to measure the effectiveness of vitamins, food, red bull, drugs, etc. For example, it may be desirable to market a product as a performance enhancer, or it may be desirable to ensure that a product does not have harmful side effects, which might manifest themselves as poor performance in a video game or other tasks. Thus, in various embodiments, players may be asked to document when they have ingested certain vitamins, food, drinks, or other items. The player's performance (e.g., game score) may then likewise be documented. In various embodiments, a player is asked to play a game or perform some other task both before and after ingesting a food, beverage, vitamin, drug, etc. In this way, the effects of the item ingested can be better discerned. In various embodiments, when a sufficient number of players have ingested an item and also performed a task, a conclusion may be drawn about the effects of the ingested item on the performance of the task.
Following an aforementioned experiment, for example, an energy drink manufacturer might advertise that after one drink, game performance is elevated for 2 hours, versus only 1 hour for the competition.
In various embodiments, a user's ingestion of an item may be documented in an automated fashion. For example, a pill bottle may communicate wirelessly with a user device, with the central controller, or with some other device. The pill bottle may automatically note when it has been opened, and transmit the time of opening to another device for documentation.
Functionality Enhancements
In various embodiments, a mouse or other peripheral may generate a collision alert. The alert may be generated when the mouse is in proximity to another item, when the mouse is heading in the direction of another item, or under some other suitable circ*mstance. It is not uncommon for a user to have a beverage (e.g., a hot beverage) on a desk with a peripheral. A collision detection alert may save the user from knocking over the beverage. In various embodiments, the alert may be in the form of a beep or some other audible sound. In various embodiments, a peripheral device will brake, such as by locking a wheel on the underside of the device.
In various embodiments, a mouse pointer may be configured to move in non-standard ways. For example, rather than moving in a continuous fashion that mirrors the motion of a mouse, a mouse pointer may follow an edge (e.g., of an application window), jump from one discreet location to another (e.g., from one text entry box to another), or take some other non-standard path. The configuration of mouse movement may be program or app dependent. For example, within the window of an app, the mouse pointer behaves one way, while outside the window of the app the mouse pointer behaves in another way.
In various embodiments, the motion of a mouse is projected from two dimensions into one dimension. The one dimension may correspond to some edge in an app, such as to the edge of a table, the edge of a row of cells (e.g., in a spreadsheet), the edge of a page, or to any other edge, or to any other one-dimensional object. Thus, for example, if a user moves the actual mouse perpendicular to the edge, then the mouse pointer does not move at all. On the other hand, if the mouse moves parallel to the edge, then the mouse pointer will move along the edge.
In various embodiments, a mouse pointer may move only between certain objects. For example, the mouse pointer moves only from one cell to another cell in a spreadsheet. As another example, a mouse pointer moves only between examples of a particular phrase (e.g., “increased revenue”) in a text document. This may allow a user to quickly find and potentially edit all examples of a particular phrase or wording. In various embodiments, a mouse pointer moves only to instances of the letter “e”. In various embodiments, a mouse pointer moves only to proper names. In various embodiments, a mouse pointer is configured to move only among instances of a particular category of words or other objects.
In various embodiments, a mouse pointer is configured to move from one text entry box to another. For example, if a user is filling in a form, each nudge of the mouse will automatically move the mouse pointer to the next box to fill in. The mouse may also auto-fill text entries based on stored information or based on deductions.
In various embodiments, a peripheral provides noise cancellation. A peripheral may receive an indication of ambient sounds, such as via its own microphone, or via signals from other devices. The peripheral may then emit its own sounds in such a way as to cancel the ambient sounds. For example, a peripheral device may emit sound waves that are of the same frequencies, but 180 degrees out of phase with the ambient sound waves. The peripheral device may further estimate the location of a user, such as via physical contact with the year, via a visual of the user (e.g., using a camera), via knowledge of a user's typical positioning with respect to the peripheral device, or in any other fashion. Having estimated the location of the user, the peripheral device may better generate sound waves that cancel the ambient sound waves at the location of the user.
Customization and Tailoring
In various embodiments, the outputs of a peripheral device (e.g., a mouse, keyboard, or headset) may be customized. Outputs may include beeps, tones, clicking sounds, pressing sounds, alerts, alerts to incoming messages, warning tones, lights, light blinks, or any other outputs. Customizations may include changing volume of a sound or other noise. For example, to avoid irritation, a user may wish to silence any audible outputs coming from a peripheral device. This may constitute a silence mode. In various embodiments, a volume of audio outputs may be set to any desired level.
In various embodiments, a particular melody, tune, jingle, tone, note, beat, rhythm, or other audio may be set for an output of a peripheral device. For example, a user may customize a sound that will be made by a mouse when there is an incoming message from another user. In various embodiments, a user may customize the sound of mouse clicks, scrolls of a mouse wheel, key presses on a keyboard, or any other sound. For example, a mouse click may assume the sound of a chime. In various embodiments, a user may customize any audible output that may be made by a peripheral device.
In various embodiments, sounds emanating or resulting from a peripheral device may be broadcast only by a headset. For example, the sound of a mouse click is broadcast only within a headset that a user is wearing. In this way, for example, sounds made by a peripheral device may avoid irritating other people in the vicinity.
In various embodiments, a user may purchase, download, and/or otherwise obtain sound effects for a peripheral device.
In various embodiments, the physical appearance and/or the physical structure of a peripheral device may be customizable. A user may have access to various component physical structures of a peripheral device. The user may have an opportunity to assemble the component structures in different configurations as desired by the user. For example, a user may have access to blocks, beams, rods, plates, or other physical structural components. These components may then snap together, bind together, screw together, join with hooks, or otherwise come together.
By assembling his or her own peripheral device, a user may customize the size of the device to best suit his hand size or hand orientation. A user may select components with a desired texture, hardness, weight, color, etc. A user may select components with a desired aesthetic. A user may also construct a peripheral device with an overall appealing shape.
In various embodiments, a user may add components that provide entertainment, distraction, or other appeal. For example, a user may build a fidget spinner into a mouse.
In various embodiments, inputs received at a peripheral device may be reflected or manifested in a game character, in a game environment, or in some other environment. Inputs received may include button presses, mouse motions, key presses, shakes of the head, nods of the head, scrolls of a wheel, touches on a touchpad or touch screen, or any other inputs. Inputs may include pressure used (e.g., to press a key or a button), speed (e.g., the speed of a mouse motion), or any manner of providing an input. Inputs may also include sensor readings, such as readings of a user's heart rate, breathing rate, metabolite levels, skin conductivity, etc. In various embodiments, features or derivative values may be computed based on inputs. For example, the rate at which keystrokes are made, the variation in time between mouse motions, the longest mouse motion in a given period of time, or any other value derived from inputs may be computed.
In various embodiments, inputs or derivatives of inputs may be translated into characteristics or attributes of a game character or game environments. Attributes may include the manner in which a character makes footsteps. For example, if a user's inputs are made with a relatively large amount of force (e.g., relative to the typical force used by a user), then the footfalls of a game character associated with the user may be more forceful. Attributes may include the footwear of a character, the attire of a character, the weight of a character, the speed at which a character moves, the facial expressions of a character, the breathing rate of a character, hairstyle of a character, or any other attribute of a character or a game environment.
In various embodiments, the weather in a game environment is dependent on user inputs. For example, if a user's heart rate is high, the clouds in the sky of a game environment may be moving quickly.
In various embodiments, a user may create custom mouse pointers. The user may create a mouse pointer that incorporates a favored picture (e.g., a picture of the user's dog), logo, or other graphic. In various embodiments, a user may send a custom mouse pointer to another user, such as by sending the mouse pointer to the other [1037] user's mouse. The other user may then have the opportunity to view the mouse pointer, e.g., reflected on a screen of an associated user device. The user may then have the opportunity to continue using the mouse pointer, or to decline to use the mouse pointer.
In various embodiments, a mouse pointer may react to its environment. For example, if the mouse pointer is a dog, and the mouse pointer comes near to a word (e.g., in a text document) describing a food item, then the dog may lick its lips.
Multiple Modes
In various embodiments, a mouse (or other peripheral device) may be capable of operating in different modes or states. Each mode may utilize received inputs (e.g., mouse click, mouse movements, etc.) in different ways. In a first mode, a mouse may allow interaction with a local or internal application (e.g., with an application 9318 running on the mouse). If the application is a survey application, then, for example, different mouse inputs (e.g., left button versus right button) may correspond to different answers to a multiple choice question. If the application is a messaging application, then, for example, the scroll wheel of a mouse may allow the user to scroll through different pre-composed messages for selection and submission to a friend.
In a second mode, a mouse may function as a traditional mouse, and inputs received at the mouse may be passed to a user device, such as to control an application being run on the user device.
As a mouse may have a limited number of input components (e.g., buttons), it may be difficult for the mouse to operate a local or internal application and serve as a traditional mouse at the same time. If the mouse attempted both, then a given input provided by a user for one purpose (e.g., to answer a survey question on the mouse) could be inadvertently misinterpreted as being intended for another purpose (e.g., as a click within an application on a user device).
Thus, it may be advantageous that a mouse can switch between modes whereby in one mode user inputs are directed to an internal application, and in another mode the mouse is functioning traditionally. In various embodiments, a user may switch between modes using some predetermined input (e.g., three rapid clicks on the right mouse button). In various embodiments, a mouse may include a dedicated switch, toggle, or other component for switching between modes. In various embodiments, a mouse may be capable of operating in more than two modes.
Social Connectivity
Various embodiments provide for a quick and/or convenient way for a player to initiate a game. Various embodiments provide for a quick and/or convenient way for a player to initiate a game with a select group of other players (e.g., friends). Various embodiments provide for a quick and/or convenient way for a player to invite other players into a gaming environment, such as a private gaming environment, or such as a private game server.
In various embodiments, a player may use a sequence of keystrokes or button presses (such as a hotkey sequence) to initiate a game, invite players to a game, invite players into a gaming environment, etc. For example, a single click of a mouse by a player brings the player's friends into a private game server.
In various embodiments, two or more peripheral devices are configured to communicate with one another. The lines of communication may allow transmission of messages (e.g., chat messages, taunts, etc.), transmission of instructions, transmissions of alerts or notifications (e.g., your friend is about to start playing a game), and/or transmission of any other signals.
However, in various embodiments, it may be desirable for a given user to indicate that the user is unwilling or unavailable to receive communications at his peripheral device. For example, the user may be working, or may be away from his user device and associated peripheral device. In various embodiments, a peripheral device may be configured to receive communications only during certain times, such as only on weekends, only between 8 a.m. and 10 p.m., etc. In various embodiments, a peripheral device may be configured to not receive communications during particular hours. These may be, e.g., “Do not disturb” hours.
In various embodiments, a peripheral device can be manually set to be unavailable as for communication. For example, when a user steps away from a peripheral device, the user may manually set the peripheral device to be unavailable to receive communications. In various embodiments, a peripheral device may automatically detect when a user has stepped away from the peripheral device, or is no longer using the peripheral device for the time being. For example, if there has been more than five minutes of inactivity, then a peripheral device may automatically configure itself to stop receiving communications. When a user returns to a peripheral device, the peripheral device may detect the usage by the user, and may once again configure itself to receive communications.
In various embodiments, if a peripheral device is configured to not receive communications, the peripheral device may transmit an indication of such configuration to any other device that attempts to communicate with it. For example, if a second user tries to communicate with the peripheral device of a first user, the peripheral device of the first user may send an automatic message to the second user indicating that the first user is not available to receive communications.
In various embodiments, a peripheral device may receive communications, but may also indicate that the user is away or is otherwise not paying attention to such communications. In such cases, for example, any communications received at the peripheral device may be stored and revealed to the user once the user is again available to peruse or respond to communications.
In various embodiments, a document may include metadata describing the author or creator of some part of the document. The document may be a collaborative document in which there have been many contributors. Example documents may include a slideshow presentation, a PowerPoint presentation, a text document, a spreadsheet, or any other document. A user may click or otherwise select some portion of the document, such as a chart of financial data embedded within the document. The user may then be shown the creator of that part of the document. For example, the name of the creator may appear on the peripheral device of the user. In various embodiments, a user may click on a portion of the document and may thereupon become connected to the author of that part of the document. The connection may take the form of a communications channel between the peripheral devices of the initiating user and of the author.
Engagement
In various embodiments, it may be desirable to ascertain an engagement level of a user. This may measure the degree to which a user is focusing on or participating in a task, meeting, or other situation. In various embodiments, it may be desirable to ascertain an engagement level of a group of users, such as an audience of a lecture, participants in a meeting, players in a game, or some other group of users. If there is low measured engagement, it may be desirable to change course, such as changing the format of a meeting, allowing users to take a break, introducing exciting material, explicitly calling on one or more users, or making some other change.
In various embodiments, engagement may be measured in terms of inputs provided to a peripheral device. These may include button or key presses, motions, motions of the head, motions of a mouse, spoken words, eye contact (e.g., as determined using a camera), or any other inputs. Engagement may also be ascertained in terms of sensor readings, such as heart rate or skin conductivity. A level of engagement may be determined or calculated as a statistic of the inputs, such as an aggregate or summary of the inputs. For example, a level of engagement may be calculated as the number of mouse movements per minute, a number of head nods per minute, a number of words typed per minute, the percentage of time that eyes were directed to a camera, or as any other suitable statistic. As another example, engagement may be calculated as a heart rate plus five times the number of mouse movements per minute.
In various embodiments, some inputs may detract from a calculated engagement level.
For example some movements of a peripheral device may be associated with distracted behavior (e.g., movements associated with playing a game while a meeting is in place). Thus, the more of such movements, the lower the perceived engagement level.
With respect to a group, an engagement level may be calculated as a mean or median of engagement levels for the individuals within the group. In various embodiments, an engagement level is calculated based on all the inputs received from the group. For example, a group is considered highly engaged if there are more than ten mouse movements amongst all the group members within a given time period. As will be appreciated, various embodiments contemplate other ways of calculating an engagement level.
Game Enhancements, Leveling the Playing Field
In various embodiments, a player may wish to celebrate, taunt, irritate, distract, or otherwise annoy another player. Ways in which one player can irritate another player include playing a sound in the other player's headset. These may include the sound of a mosquito, bee, baby crying, siren, fingers on a chalkboard, Styrofoam™ bending, a shrieking wind, or any other irritating or distracting sound. In some embodiments, the sound may be controlled by one player who has won a battle or a round of a game, and they may be able to continue the sound for a certain period of time, while the receiving player cannot turn it off, or down.
In various embodiments, a player may pay for pre-packaged taunts. These may include pre-recorded phrases, sounds, images, videos, or other media that can be used to taunt or annoy another player. In other embodiments, these may also include phrases, sounds, images, videos, or other media that the player can record themselves. When triggered by a first player, the taunts may be delivered to a second player (e.g., with the intermediation of the central controller or some other intermediate device). In various embodiments, a taunt is communicated directly from a first user's peripheral device to a second user's peripheral device.
In various embodiments, a player may receive pre-packaged or recorded media in other ways, such as a reward for winning.
A first player may also irritate a second player by causing the second player's mouse to act in various ways. The second player's mouse cursor may write out “you suck”, or some other taunting phrase or gesture. The mouse pointer itself may change to “you suck”, “Player 1 rules,” or to some other taunting phrase or gesture.
In various embodiments, random inputs or outputs may be added to a player's peripheral device as a way to irritate the player. For example, random motions may be introduced to a player's mouse, or added to the intentional motions made by a player with a mouse; or the motions made by a player may be left-right swapped, or up-down swapped, or randomly magnified or scaled down, or randomly slowed down or sped up, or completely disabled for a period of time. Random keys may be pressed on a player's keyboard, or some keys may be disabled, or the entire keyboard may be disabled for a period of time. Random noise, or pre-recorded messages, music, or other sounds may be added to a player's audio feed so that the player has a harder time hearing and processing what is happening in a game. In other embodiments, a player's display may be dimmed, flipped upside down or left-right flipped, or random colors or images may be introduced, or the display could be completely disabled for a period of time. As will be appreciated, other distracting or random inputs or outputs may be added to a player's peripheral device or to any device associated with a player.
In various embodiments, a player of a game may wish to be informed of choices or actions made by other players under similar circ*mstances to those currently facing the player (or under circ*mstances that the player had encountered). This may allow a player to learn from the decisions of other players, to become aware of what other players did, and/or to compare his own performance to that of other players. When a player reaches a particular game state, the central controller may recount other times that other players had been in similar states. The central controller may generate statistics as to what decision or what actions were made by the other players in the similar game states. The central controller may cause such statistics to be presented to the player. For example, a player may be informed that 60% of players took a left at a similarjuncture in the game, with an average subsequent score of 234 points. On the other hand, 40% of players took a right with an average subsequent score of 251. In various embodiments, a player may wish to see decisions of only a subset of other players. This subset of other players may be, for example, the player's friends, or top players.
Some Embodiments
In various embodiments, a user may receive offers of work, labor, jobs, or the like. Such offers may come via peripheral devices. For example, offers may be presented on the screen of peripheral devices. In various embodiments, the work offered may involve the use of such peripheral devices. For example, work may include editing documents, providing instruction on using a peripheral device (such as in the context of a particular application), controlling a video game character through a tricky sequence, answering a captcha question, assisting a handicapped user, or any other offer of work. In return for performing work, a user may receive payment, such as monetary payment, game currency, game privileges, or any other item of value or perceived value.
In various embodiments, the usage of peripheral devices may indicate the presence or absence of employees (or other individuals) at a company, or other organization. For example, if an employee's mouse is not used all day, it may be inferred that the employee was absent. Company-wide (or department-wide, etc.) data may be gathered automatically from peripherals to determine patterns of employee absence. Furthermore, peripheral devices may be capable of determining their own proximity to other peripheral devices. For example, a peripheral device may determine that it is near to another device because a wireless signal from the other device is relatively strong.
Proximity data, compared with usage data, may allow a company to determine a spatial pattern of absences among employees. This may, for example, represent the spread of an illness in a company. For example, it may be determined that 80% of employees within twenty feet of a given employee, were absent. Further, the presence or absence of employees may be tracked over time. In this way, a spatial pattern of absences may be correlated to a temporal pattern of absences. For example, it may be determined that, over a given five-day period, the number of absent employees has been increasing, and the distances of the desks of newly absent employees has been increasing relative to a fixed reference point (e.g., to the first employee in a company who was sick).
In various embodiments, peripheral devices may provide early warnings of contagious illness within a company. This may allow a company to take proactive actions to prevent further illness among its employees. This may, in turn, increase employee morale, reduce sick days, reduce insurance costs, or provide other benefits.
In various embodiments, peripheral devices may detect other signs of illness. Such signs may include sneezing (e.g., detected via a microphone), skin conductivity, or other vital signs, or other biometrics. Employees suspected of being ill may be allowed to leave early, may be given their own private offices, may be provided with a mask, etc.
In a gaming context, a player or a viewer may click on another player's character and see what hardware that character is using. There may be a link to purchase the hardware. An avatar may wear a logo or other indicia indicating which hardware is currently controlling it.
In various embodiments, a teacher, professor, or other educator may wish to receive feedback about student engagement. Feedback may be particularly useful in the context of remote learning where a teacher may have less direct interaction with students. However, feedback may be useful in any context. In various embodiments, feedback may take the form of biometrics, vital signs, usage statistics, or other data gathered at students' peripheral devices.
In various embodiments, a heart rate is collected for the entire class and the average (or some other aggregate statistic) is sent to the teacher (e.g., to the teacher's mouse). The statistic could be displayed in different colors depending on the value of the statistic. For example, if the average heart rate is high, the teacher might see the color red on her mouse, whereas the teacher might see green if the average heart rate is low. It could display in a different color if elevated. Information about students' heart rates, or other vital signs, may allow a teacher to determine when students are anxious, confused, unfocused, etc. The feedback may allow a teacher to adjust the learning activity.
In various embodiments, an educator may receive information about whether or not students' hands are on their respective mice. If there is a lack of mouse movement among students (e.g., on average) then this may be indicative of a lack of engagement by students.
In various embodiments, rather than receiving continuous feedback about student engagement, a teacher may receive alerts if engagement data or engagement statistics satisfy certain criteria. For example, a teacher receives an alert if the average number of mouse motions per student per minute falls below 0.5. The alert may take the form of a colored output on the teacher's peripheral device (e.g., the teacher's mouse turns red), or it may take any other form.
In various embodiments, a teacher may cause the peripheral devices of one or more students to generate outputs. Such outputs may be designed to grab the attention of students, to encourage student engagement, to wake up students, or to accomplish any other purpose.
In various embodiments, a teacher may cause a student's peripheral to exhibit movements (e.g., a mouse may vibrate, keyboard keys may depress and elevate), to produce sounds, to show color, or to otherwise generate outputs. Such outputs may be designed to encourage student engagement.
In various embodiments, a teacher pushes a quiz to students. The quiz may be presented via a student's mouse or via some other peripheral device. Each student may receive a randomized quiz. For example, each student may receive different questions, or each student may receive the same questions but in different orders, or each student may receive the same questions with multiple choice answers in different orders. The randomization of quizzes may reduce the chance of collaboration among students. Three clicks by one student may be the right answer/response for that one student, and two clicks and a tracking ball move may be the right answer to the same question for another student.
Mouse Output Examples
In various embodiments, a mouse is used to output information to a user. The mouse could contain its own internal processor. Output from the mouse could take many forms. Because some of these embodiments could include relatively expensive components, the mouse could include hardening or an external case of some kind to protect the mouse.
In various embodiments, a mouse includes a display screen, such as a digital display screen. This could be a small rectangular area on the surface of the mouse which does not interfere with the activity of the user's fingers while using the mouse. This display area could be black and white or color, and would be able to display images or text to the player. This display would receive signals from the user device or alternately from the central controller, or even directly from other peripheral devices. The screen could be touch enabled so that the user could select from elements displayed on this digital display screen. The screen could be capable of scrolling text or images, enabling a user to see (and pick from) a list of inventory items, for example. The screen could be mounted so that it could be flipped up by the user, allowing for a different angle of viewing. The mouse display could also be detachable but still controllable by software and processors within the mouse.
In various embodiments, a mouse includes one or more lights. Lights (e.g., small lights) could be incorporated into the mouse, allowing for basic functionality like alerting a user that a friend was currently playing a game. A series of lights could be used to indicate the number of wins that a player has achieved in a row. Simple lights could function as a relatively low-cost communication device. These lights could be incorporated into any surface of the mouse, including the bottom of the mouse. In some embodiments, lights are placed within the mouse and can be visible through a semi-opaque layer such as thin plastic. The lights could be directed to flash as a way to get the attention of a user.
In various embodiments, a mouse may display or otherwise output one or more colors. Colors may be available for display or configuration by the user. The display of colors could be on the screen, mouse buttons, or on any other part of the mouse (or on keys of keyboard). In various embodiments, colors (e.g., color, intensity, color mix, etc.) may be adjusted by the trackball or scroll wheel, or varied by the sensory information collected. The intensity of lights and colors may also be modified by the inputs and other available outputs (games, sensory data or other player connected devices).
In various embodiments, a mouse may generate output in the form of motion. This could be motion of the device forwards, backwards, tilting, vibrating, pulsating, or other motions. Motions may be driven by games, other players, actions created by the user, or by any other cause. Motion may also be delivered in the form of forces against the hand, fingers or wrist. The mouse/keyboard device could become more firm or softer based on the input from other users, games, applications, or by the actual user of the mouse/keyboard.
In various embodiments, a glove may be a peripheral device. In various embodiments, a glove may be part of a peripheral device. For example, a glove may be attached to a mouse. A device attached to a mouse could allow for compression or pulsing of the hand for therapy purposes. The device could provide feedback to the user from other users by simulating compression and pulsing as well.
In various embodiments, a mouse may generate output in the form of sound. The mouse could include a speaker utilizing a diaphragm, non-diaphragm, or digital speaker. The speaker could be capable of producing telephony tones, ping tones, voice, music, ultrasonic, or other audio type. The speaker enclosure could be located in the body of the mouse.
In various embodiments, a mouse may generate output in the form of temperature. There could be an area (e.g., a small area) on the surface of the mouse or on keyboard keys which contains heating or cooling elements. These elements could be electrical, infrared lights, or other heating and cooling technology. These elements could output a steady temperature, pulsating, or increase or decrease in patterns.
In various embodiments, a mouse may generate output in the form of transcutaneous electrical nerve stimulation (TENs). The devices could contain electrodes for transcutaneous electrical nerve stimulation. These electrodes could be located in the surface of the mouse corresponding with areas used by fingertips or by the palm of the hand. These electrodes could also be located in a mousepad or in ergonomic devices such as a wrist rest.
In various embodiments, a mouse or other peripheral device may generate output in the form of smells, scents, or odors. A peripheral device may output scent via an air scent machine (odor wicking or scent diffuser). The devices could contain an air scent machine, either a scent wicking device or a scent diffusing device. This air scent machine could be located in the body of the mouse.
In various embodiments, a mouse may convey messages or other information using standard signals provided to a user device, thereby causing a mouse pointer to move on the user device in a desired way. For example, a mouse may cause a mouse pointer to trace out the word “Hello”. In various embodiments, a mouse may cause a pointer to rapidly trace and retrace the same path, thereby creating the illusion of a continuous line, ark, or other shape. I.e., the mouse may cause the mouse pointer to move so quickly that the human eye is unable to discern the mouse pointer as its own distinct object, and sees instead the path traced out by the mouse pointer. In this way, a mouse may output text, stylized text, shapes (e.g., a heart shape), images, cartoons, animations, or any other output. An advantage of creating messages in this way is that such messages need not necessarily be application-specific. In other words, the mouse may cause a cursor to move along a particular trajectory regardless of the application at the forefront of the user device.
In various embodiments, a mouse may convey a message through interaction with an application on a user device. For example, a user device may have a keyboard app that allows a user to “type” alphanumeric keys by clicking on a corresponding area of a displayed keyboard. To convey a message, the mouse may automatically move the mouse pointer to appropriate keys and register a click on such keys, thereby causing the message to be typed out. For example, to convey the message “hello”, the mouse may sequentially cause the cursor to visit and click on the “h”, “e”, “I”, “I”, and “o” keys.
In another example, a mouse may interact with a drawing application (e.g., with Microsoft® paint) to create shapes, drawings, etc., for a user to see.
In various embodiments, a mouse or other peripheral may store a script or other program that allows it to interact with an application in a particular way (e.g., so as to output a particular message).
In various embodiments, a mouse or other peripheral may have a message to convey to a user, but may require that the user be utilizing a particular application on the user device (e.g., the mouse may only be able to deliver the message through Microsoft® paint). In various embodiments, the mouse may detect when a user is using the appropriate application from the user's mouse movements. The mouse may recognize certain emotions as indicative of use of a particular application. The mouse may then assume that such application is in use, and may then cause a message to be conveyed to the user with the aid of the application.
Software
The peripherals according to various embodiments may include processors, memory, and software to carry out embodiments described herein.
Mouse/Keyboard with Stored Value
Mice or keyboards according to various embodiments may become personalized, and could contain items of monetary value such as digital currencies, game rewards, physical items, coupons/discounts, character skins and inventory items, etc. It could also store the identity of the player (and the identity of her game characters), game preferences, names of team members, etc. Game highlight clips could also be stored for later viewing or uploading to a central controller. Access to the stored value/data could require the user to provide a voice print, password or fingerprint to gain access. The value could also be stored with a user device (or central controller) and accessed through a mouse or keyboard.
In various embodiments, users could store their identity for use across games, computers, and operating systems. For example, the mouse could store the player names and passwords associated with all of their favorite game characters. This would enable a player to take their mouse from their home and go to a friend's house to use it during game play there. The user device (e.g., game console) owned by their friend would then read in data from the user's mouse, enabling that user to log in with any of their characters and have access to things like saved inventory items like a +5 sword or a magic healing portion. The user's mouse could display the items in inventory on a display screen of the mouse, allowing the user to touch an item to select it for use, with the mouse transmitting the selection to the user device, game controller, or central controller. The user could also have access to store preferences and customization for things like custom light patterns on their mouse. The user's mouse might also have stored game value that would allow a user to buy game skins during a game session at their friend's house.
Because the mouse or keyboard might include items of value, in some embodiments the user must provide a password in order to gain access to the mouse. For example, the user might have to enter a PIN number by touching digits that are displayed on the surface of the mouse, or enter a PIN into the user device which then uses that PIN to get access information from the central controller in order to get access to the value in the mouse. Items stored within the mouse or keyboard could be encrypted, with the user required to provide a decryption key in order to retrieve the item. In other embodiments, unique biometrics (such as an iris scan, fingerprint, heart rate, and the like) could be required in order to gain access to the value stored in the mouse. In one embodiment, the value is unlocked when a unique pace of mouse movements or keyboard pacing matches to those of the user.
In various embodiments, the mouse itself could store encryption/decryption keys for use by the user device, allowing the mouse to act like a secure dongle.
With payment transaction software and processors/storage within the mouse, various embodiments could enable users to make microtransactions in-game. For example, a user could provide a credit card number to the central controller and arrange to have $20 in value loaded onto the storage area of the user's mouse. When the user is then playing a game, he could encounter an object like a Treasure Map that could be obtained for $1. The game controller sends the offer to the display screen of the user's mouse, and the user then touches an acceptance location and the $1 is taken out of the $20 in stored value and transferred to the game controller or central controller, after which the Treasure Map is added to the inventory items of the player, either in-game or within the user's mouse itself.
In various embodiments, micropayment transactions could also enable a user to rent game objects rather than buying them. For example, the user might want to obtain a rare game skin for his character in a game, but feels that the purchase price of $10 is too high. After rejecting the purchase, the game controller could send an offer to the user's mouse of a weekly rental period for the game character skin for $1/week. The user accepts the offer and $1 is transferred to the game controller or central controller and the character game skin is then enabled for that user. Each week the player pays $1 until cancelling the subscription. Alternatively, the subscription could be for a fixed period of time, or for a fixed period of game time. For example, the player could get ten hours of use of the game character skin for $1.
Another use for micropayment transactions is to allow a user to send small amounts of money to another player, transferring funds from the user's mouse to the central controller to the mouse of the other user. Such transactions could also be used to support game streamers by enabling simple and quick transfers of value to the streamer.
Some games have treasure chests that a user can elect to open, either by paying an amount of gold coins from the game or real money (such as a micropayment from stored value in the user's mouse) or by simply electing to open it. In one embodiment, the treasure chest requires a random selection from the user. For example, the player might pick a number between one and five (by pressing the number on the touch enabled display screen on the surface of the user's mouse), with the Treasure Chest only opening if the player selected the number four.
In various embodiments, a mouse may reveal or unlock items in a game. For example, a player using a mouse may see hidden trap doors when hovering the mouse pointer over a particular region in the game area. A mouse may enable access to particular game levels or areas that may otherwise be inaccessible.
By creating a physical storage location within the mouse, the user could store items like a ring, sentimental items, currency, coins, mementos, etc. For example, the user could store a thumb drive within a locked portion of the mouse, with access requiring the use of a password or thumbprint to access.
Physical items could also be included in the mouse by the manufacturer, with the user able to access that item after achieving a goal such as using the mouse for ten hours, achieving a particular level of a particular game, identifying a list of favorite games, or the like. Once this goal had been achieved, the user device could send a signal to the mouse unlocking the compartment which held the manufacturer's object. To make the object more secure, the compartment could be designed such that attempting to break the compartment open would result in the functionality of the mouse being disabled or reduced in capability. Attempts to break open the compartment could also generate a signal sent to the user device which would then initiate a phone call to the user of the device and also trigger a camera to get video/photos of the mouse.
Gameplay could also unlock keys on a keyboard. For example, the user's keyboard could have three keys that are initially non-functional. They are enabled as the user completes certain goals. For example, the user might have a key unlocked when the user defeats ten opponents in a 24-hour period. This unlocked key could enable a user to open a communication link to game secrets that would improve their chances to win a particular game.
Another aspect of the user's identity is rating information about the user's ability to play a particular game, or a rating of the user's ability to function well on a team. For example, a user's mouse might store an evaluation of the user's team skills, such as by storing a rating (provided by other players or determined algorithmically by one or more game controllers) of 9 on a 10 point scale. When the user uses his mouse to play in a new game, that new game can access the 9/10 rating from the user's mouse and use the rating to match the user with other players of a similar team rating level. Even though the user may have never played that particular game before, the user's team rating would allow the player to join a more experienced team than the user's beginner's status would at first indicate.
Access to a mouse or keyboard could also be used by other parties to restrict game play. For example, a parent might set play time parameters for a mouse that would lock out a user when that user exceeds three hours of game play in a given day, or it could lock the player out between the hours of 3 PM and 6 PM on weekdays. The mouse or keyboard could also be restricted to certain types of game. For example, the mouse could be set to not operate in a third person shooter type of game.
Access to the mouse could also be restricted based on the condition of the user. For example, the user device or game controller might determine that, based on the mouse inputs currently being received, the user seems to be reacting slower than normal. This might be due to the player being tired or sick. If the player falls below a threshold amount, such as a reaction time of 90% or less of normal, then the mouse could be instructed to end current game play for a predetermined period of time, such as one hour. After that hour is up, the user would again have access to the mouse, but further checks of reaction time would be made. The mouse could also end game play if the user appeared to not be playing their best game. For example, a user playing three minute speed chess might have the game controller set to send the user's current chess rating to be stored in the mouse, and when that rating falls by 100 points the mouse automatically ends game play for a period of time. A user playing poker might have access to the mouse and keyboard denied after the user most too much money or was playing in a way that was indicative of a player on tilt.
Stored value in a mouse could also be used to pay for items outside of a game environment. For example, a user at a coffee shop with a laptop computer and mouse could use value in the muse to pay for a coffee. In another embodiment, value stored in a mouse could be used to buy dinner via Seamless.
In various embodiments, value stored in a mouse could be locked up if the mouse was taken out of a designated geofenced area.
In various embodiments, stored value is associated with a mouse or with another peripheral. Value may take physical form, such as gold or currency physically locked inside of a mouse. Stored value may take other forms, such as cryptocurrency, electronic gift certificates, etc. In various embodiments, a user may perform certain actions on a peripheral in order to unlock, receive, or otherwise benefit from stored value. In various embodiments, a user must type in some predetermined number of words (e.g., one million words) to unlock value. In various embodiments, the words must be real words, not random key sequences. In various embodiments, a user must make a certain number of cumulative mouse motions in order to unlock value. For example, the user may move a mouse for one kilometer in order to unlock value.
In various embodiments, a mouse/keyboard or other peripheral device could respond to game conditions; in various embodiments, the mouse and keyboard may gain or lose functionality, or have altered functionality as a result of in-game development, and/or as a result of player actions during a game. In various embodiments, as a result of a player action, or an in-game development, a peripheral device becomes disabled for some period of time. For example, if, in a game, player one shoots the gun out of player two's hand, then player two's mouse may become disabled for thirty seconds. As another in-game example, if player one kills player two, player two's mouse and keyboard are disabled for five minutes. As another example, if a player takes damage in a game (e.g., in boxing), the player's mouse response lags or precision drops. As another example, if a player is drinking alcohol in a game (or while playing a game), mouse responsiveness becomes unpredictable, lags, or the keyboard begins to output more slowly or the wrong character now and then. Gainers would have the option of limiting this type of control to certain people.
In various embodiments, a player may pay to recover lost functionality of a peripheral device. The player may be able to pay to recover lost functionality immediately, or may pay to reduce the period of time for which functionality is lost. A player might pay the central controller, a game provider, or the person who caused the player to lose functionality in his peripheral device.
Mouse Extra Sensors Alter In-Game Character or Avatar or Actual Response from a Mouse-Keyboard
A peripheral device (e.g., mouse, keyboard, etc.) may be equipped with various sensors that allow for collection of sensory data. This data could be used to alter the experience of the user(s) in both the virtual world (e.g., the game or virtual activity) and physical world (e.g., the physical mouse or keyboard).
In various embodiments, a mouse includes an accelerometer and/or another motion sensor. The sensor may be used to control the movement of objects in a game, including the movement of objects in three dimensions in a game. The sensor may also be used to control the movement of objects in other environments. In various embodiments, a user may provide an input to the sensor by positioning the mouse, such as positioning the mouse somewhere in 3-D space. A player in a game could use the accelerometer data to control the 3-D movement of objects either above, below, in front or behind the player. This is in contrast to the current 2-D dimensional play and movement. As an example, a player engaged in a combat game could pick up a flare and instead of using a 2-D enabled button or mouse control to launch the flare, the accelerometer equipped mouse could allow the user to move the mouse up to throw the flare up in the air or in the direction the mouse moves. This provides a more realistic experience for the game player.
In various embodiments, an accelerometer or other motion sensor may sense movement or momentum. For example, a user may move a mouse. In response, a character may move in the direction and pace of the mouse. Conventionally, movement of a character is controlled by static processing of buttons or joysticks to move the character in various directions within a game. In order to provide a more enhanced experience, the sensor-enabled mouse could be used to control the pace of movement and direction of the character. For example, if a character is running from the enemy, the mouse could be picked up and held with arms moving as if the user were running. The movement of the arms and pace of the arms could be reflected in the character and their movement. Once the arms stop moving, the character stops. If the user moves to the left, right, jumps up or lowers, the movement of the mouse in those directions could be reflected in the character as well.
In various embodiments, a user may move a mouse to perform a desired action in a game. Movements may include: the tap of the mouse on a surface; the tilting of the mouse to the left, right, front or back; quick movement to the left or right (front/back); or any other movements. Conventionally, mouse clicks or finger taps on a mouse may reflect some action that the user wants to occur on the screen. With a sensor-equipped mouse, the various unique movements of the user could reflect their specific choice in a game or any application setting. For example, as a card game player, the user may signal the dealer to deal another card by simply tapping the mouse; if the user wants to pass, they may quickly move the mouse to the right; or if the user wishes to fold and end the game, they may raise the back of their mouse. These movements could be configured to reflect actions particular to each game.
In various embodiments, a mouse may contain a tactile sensor. A tactile sensor may include galvanic sensors or other tactile sensors. The tactile sensor may be used, for example, to measure and adjust excitement level of the user. A tactile sensor may gather sensory information collected through the skin (e.g., temperature, pressure, moisture, metabolites, vibration).
Many games have predetermined levels and paths to successfully accomplish the game. Users either navigate successfully without much difficulty or fail repeatedly trying to accomplish a task. Measuring the relative excitement/intensity/frustration level (or lack thereof) may possibly make the game more fun. With the collection of sensory data in the mouse-keyboard, the tactile data collected could be used to alter the user experience and make the game more or less difficult. For example, a skilled game player may always navigate through a section of the game with little or no trouble. The tactile sensor is reading that the player's skin temperature, pulse rate and pressure applied to the mouse-keyboard are relatively consistent. In this case, to add to the excitement, the game could automatically introduce new and more challenging scenarios to raise the heart rate, force applied to the mouse-keyboard and overall temperature of the player. Conversely, if a novice player repeatedly fails in areas of the game and the tactile sensors are reading elevated levels, the game could provide on screen coaching to maneuver through the game or introduce easier levels to increase their skill.
In various embodiments, a tactile sensor may measure excitement levels in one player. Other players may then be apprised of the player's excitement level. In various embodiments, sensory information is collected through the skin (e.g., temperature, pressure, moisture, vibration information). Today, player information is either observed on screen or through audio queues. With the collection of tactile information from all players via mouse-keyboard, this information could be sent to each player's mouse-keyboard as another piece of data to enhance the experience and gain insight to their opponents reaction to the game. For example, a player may have an increased heart rate or elevated temperature during an intense battle. This information could be sent to an opponent's mouse-keyboard via lights/vibration during the game in order to adjust their playing style. If they are your enemy in the game, you may notice they are getting agitated and may wish to bring in other forces as they are nearing a point of failure. On the other hand, if the tactile sensory data provided indicates a teammate has increased sensory data and is reflected in your mouse/keyboard, you may wish to abandon your current task and go to assist.
In various embodiments, a tactile sensor may take measurements, which are then reflected in a user's avatar. In various embodiments, a tactile sensor may collect galvanic measure of temperature or moisture levels. Using galvanic measurements, the collected information could reflect in the in-game avatar. For example, if the sensor measures a person's temperature or moisture level (sweat) increasing, the in-game avatar could dynamically change to show the avatar sweating, face becoming red, facial expression of exhaustion, change of clothing to reflect body temperature (e.g., the avatar may wear lighter clothing), and/or the avatar may consume fluids. Conversely, if the sensor measures indicate a calm manner, the avatar could show a pleasant expression, casual stride or cooperative behavior.
In various embodiments a mouse or keyboard may include a biometric sensor. The sensor may determine a heart rate or other vital sign or other biometric measurement. The sensor reading may be incorporated into a game. In various embodiments, a finger sensor (or other sensor) collects the heart rate of the user. The heart rate of the player (user) is collected and provided to the other game players with sensor-enabled mice or keyboards. As the heart rate of the player is collected, the pulsing rate is sent to the other users in the form(s) of light pulses or actual vibration reflecting the exact heartbeat of the player. As a player enters an intense part of the game, or when the player loses the game, the player's heart rate may increase. In various embodiments, this increase in heart rate may be seen in another's mouse-keyboard and/or felt via a corresponding vibration. This allows each player to feel more connected to the physical person, making the game appear more realistic.
In various embodiments a mouse or keyboard may include a force sensor. In various embodiments, the force sensor may allow force or pressure controlled movement of game/application items. Forces applied to a mouse-keyboard can be used to invoke actions in a game or application. For example, in a combat game with multiple weapon types, each may require a different level of force to pull a trigger. Instead of clicking a button or moving ajoystick to fire a weapon, force applied to a mouse could be used. If one weapon is easier to shoot, the force needed on the mouse could be minimal, whereas larger, more complex weapons may require a higher degree of pressure and/or may require pressure from multiple locations on the mouse-keyboard (e.g., two fingers and the palm of your hand).
As a competitor, the player may wish to manipulate the play of their opponent. The game could allow the player to increase the mouse pressure making it more difficult for an opponent to engage a weapon, or require them to use multiple force actions on the mouse-keyboard to engage a weapon.
In various embodiments, an amount of force or pressure sensed may indicate tension/frustration on the part of a player. Such tension or frustration may be reflected in an avatar. Using forces applied to the mouse-keyboard could indicate frustration by the user. In this case, the in-game avatar could display an expression of frustration or the game could adjust to make elements of the game easier until the frustration level is reduced. If the mouse-keyboard are slammed on the table, this could reflect frustration and cause the avatar to slam their fist on an object or stomp on the ground in a game.
In various embodiments a mouse or keyboard may include one or more lights. In various embodiments, lights may adjust light to display activity, such as player activity. In various embodiments, data about player activity may be collected including player progress, opponent progress, availability, excitement level, rating, etc. Player (user) information may be collected in game or on device; opponent (other user) information may be collected in game or on device or via other connected devices.
Using information collected from multiple sources such as sensor equipped mouse-keyboard, external data sources like weather alerts, amber alerts, alarm systems, temperature sensors, gaming data from other opponents, player availability indicators (active indication versus calendar notification), the lights on a mouse-keyboard could be turned on, off, adjust brightness and patterns to reflect the specific event taking place. For example, if the player is engaged in a combat gaming scenario, the lights on a mouse-keyboard may display a rapid pulsing bright red color on the mouse or keyboard to indicate the battle is intense. On the other hand, if my doorbell rings, my mouse may suddenly reflect a bright green light indicating someone is at the door. These colors, patterns and brightness levels can be adjusted by the user.
Players often have teammates they frequently engage in games. When one player wants to play a game, they may wish to alert others of their availability or see another player's availability. For example, if one player is available to play a game, they may simply press a button on the mouse-keyboard that immediately lights up a green indicator on their friend's mouse-keyboard. This signals to their friend to join a game. Conversely, if for some reason a player is not able to play a game, they could hit a button on the mouse that indicates to others they are not available. This could be a green color or any other visual indicator.
In various embodiments a mouse or keyboard may include one or more audio output devices. In various embodiments, the audio output may be used to locate a misplaced device. In various embodiments, users desire the ability to find devices. As the mouse-keyboard becomes more customized devices that are carried from location to location, the opportunity to lose the device increases. Users may desire the ability to ping their device. For example, if a player takes their mouse to a friend's house to play a game and it is misplaced, the user can log in to their other electronic device and ping the mouse. The sound from the mouse-keyboard can be heard and the device located.
Game players or other users can send an audio signal to a mouse-keyboard. During a game, a user may send their friend or opponent a sound to distract them, encourage them or alert them. For example, if a person is playing a combat game and they ambush an opponent, they could send a loud sound to their opponent to scare them or distract them. Likewise, if during a game they see their teammate about to be attacked, they could alert them via a sound. Furthermore, at the end of a successful win, all team members' sounds could play various tones indicating success.
In various embodiments a mouse or keyboard may include a metabolite sensor. The metabolite sensor may collect or detect chemical content (e.g., potassium, sodium content).
Game players, when alerted to low levels of potassium or sodium (or any measured chemical level via the sensor), could have the game and avatar modified to indicate the response requested in the physical world. For example, if the sensor detects low levels of potassium, the game avatar may suddenly pick up a banana to eat or have it incorporated in the game to find and eat as another challenge. This may also remind the player to actually eat a food rich in potassium to resolve the deficiency. Likewise, other players that notice this activity may also be reminded to encourage the player to eat a food rich in potassium. In this regard, all players are observing and suggesting to each other to maintain good health habits.
In various embodiments, a mouse or keyboard may include an electroencephalogram (EEG) sensor. The EEG sensor may collect brainwave activity.
Game play invokes brain waves and can provide insight into the physical impacts of games on a player's brain and also how to develop more challenging and intense games. A headband that measures brain waves could be used to collect this data and send the data to a central controller (possibly via a connected or associated mouse-keyboard) for analysis.
During a game, the EEG sensor could determine if you are having a headache and adjust the game to lessen the intensity. In addition, the brightness in the room, game, mouse-keyboard and any sensory controlled device in the room could be adjusted to lessen the impact on the brain and headache intensity.
During the game, if brain activity indicates stressful signals, the in-game avatar could dynamically change to indicate a potential issue by placing their hands on their head, taking a break or signaling to other players they are not feeling well. This could be an early indication to the player as well that a break from the game is needed.
During a game, if the brain signals are not very active, the game could dynamically change to introduce more complex or challenging activities to stimulate the brain.
In various embodiments a mouse or keyboard may include an electrocardiogram (EKG/ECG) sensor. The EKG/ECG may collect cardiac electrical waveforms. This may allow for game intensity to be measured and adjusted. As games become more complex or other players introduce activities that engage a player, the heart rate can be measured. If the heart rate increases, decreases or remains consistent, the game could be adjusted accordingly. For example, if a user is playing a soccer game and is constantly making goals while their heart rate remains constant, it may indicate the game is not challenging and could lead to boredom or switching the game. The game could introduce more challenging opponents or adjust the player skill and make it more difficult to score goals. Likewise, if the player's heart rate is elevated for an extended period of time, the game difficulty could be adjusted to allow for recovery of the heart and a slowing of the heat rate.
In various embodiments a mouse or keyboard may include an electromyography (EMG) sensor. The EMG sensor may collect muscle response.
The mouse-keyboard could be equipped with an EMG sensor to measure muscle activity in the hands, fingers, wrists and arms. The user's muscle response to a game can be measured and game play adjusted. For example, if the EMG recognizes that the hand on the mouse demonstrated weak muscle activity, the sensitivity on the mouse-keyboard could change dynamically to not require such intense pressure to invoke a function during a game. If a user is shooting a weapon and requires pressing of a button, the button friction could change to make it easier if the EMG recognizes weak muscle response.
In various embodiments, players' skills may be ascertained based on EMG data.
Adjustments may be made to level the playing field among different players. In order to create a more uniform play for games requiring teams, the EMG data collected from all players could be used to adjust the necessary mouse-keyboard settings, removing any advantage any player may have. For example, if a group of players are engaged in a team sport (e.g., football) and the passing, kicking and handoffs require a mouse-keyboard to be used with some level of muscle activity, those with stronger muscles may have an advantage. Adjusting each player's mouse-keyboard to be consistent so all players' intensity is the same, could provide a more balanced game.
In various embodiments, an EMG sensor in a mouse (or other peripheral) may detect if a player is leaning forward.
In various embodiments, a mouse or keyboard may include a proximity (IR-Infrared) sensor. The proximity (IR-Infrared) sensor may collect information indicative of obstacles or objects in the room.
In various embodiments, using proximity sensors in a mouse-keyboard device can alert the user of objects in the room. Oftentimes a user's back is facing a door making it difficult to see if someone walks in or is looking at the user's computer screen. The proximity sensor can provide the user with immediate information that someone is near them. This can be done by interfacing to the computer screen (or application), providing a message or visual indication of the actual object. The mouse-keyboard could vibrate or display a different color as well.
External Sensors Change In-Game Environment or Virtual Environment
The proliferation of external sensors allow for the data collected to be included as part of a user's in-game experience and reflect an indication of what is taking place in the real world.
In various embodiments, weather sensor data is reflected in a game. The game can collect real-time data from the various weather sources (such as the national weather service) for the physical location in which the player is playing the game. If the central controller receives data indicating rain in the area, the on-screen game environment could change to make it appear that it is raining or provide a sound mirroring the real weather events. In addition, if it is raining in the game environment, an in-game avatar could change to reflect that rain gear is worn. Another example could be tornado activity in the area. If this occurs, the game could alert the player by flashing lights on the player's mouse to get his attention. The player, who may be distracted by the game, could be instructed to take cover and look for a safe place. Likewise, a tornado could display on the screen and disrupt the player's competitors.
The indication of thunder in real life could cause the mouse or keyboard of remote team members to vibrate to mirror the feeling of thunder. The same could be done if a snowstorm or heat wave is in the area and the temperature of the mouse or keyboard dynamically changes.
In various embodiments, garage door/doorbell data is reflected in a game. An increased number of garage doors are monitored and controlled electronically. This data could be displayed on the user's game screen or mouse display area as informational to the player/user. For example, as a teenager who is playing a game after school, they may want to be notified that the garage door/doorbell is being activated to determine who is home or to stop the game and focus on another activity (e.g., homework, chores, dinner).
In various embodiments, time of day can be mirrored in the sun/moon brightness on the mouse or keyboard. Based on the geographical location of the mouse, external sources such as the national weather service could provide the sunrise/sunset/cloudiness/moon brightness data. This information can be reflected in the mouse or keyboard display. For example, if the user is playing a game at 2 pm when the sun is bright, the keyboard backlighting could illuminate a bright sunny color. As time progresses and gets closer to dusk, the illumination in the keyboard backlighting could dynamically change to mirror the conditions outside—becoming less bright and softer in color. When sunset occurs and it is dark, depending on the brightness of the moon, the keyboard could adjust to reflect this intensity as well. A sun/moon could display on the mouse screen to match the ambient environment throughout the day.
In various embodiments, ambient sounds could change the in-game environment. Microphones on the user's peripheral devices could detect sounds within the environment of the player to incorporate into the game environment. For example, if the bark of a dog was picked up by a microphone, the game controller could add a barking dog character into the game environment. Users could transmit a photo of the dog to the game controller so that a virtual representation of the user's dog can be seen in the game environment. In another embodiment, when a peripheral microphone picks up loud sounds, the game controller could create a sign in the game environment above the head of the user's game character which says “Currently in noisy environment.”
In various embodiments, local news/events could be incorporated in the in-game environment. Items from a newsfeed (e.g., a feed of news that is local to the player's location) can be incorporated into a game. For example, an in-game billboard may display, “Congratulations to the Jonesville high school football team!!”
Sharing of Video Highlight Reels
When game players have success while playing a game, they sometimes want to brag about it to their friends, but that process can be clumsy and complicated. Various embodiments allow for players to quickly and easily capture video of game highlights and make them available in a variety of formats that make sharing them more fun and enjoyable. One or more peripherals can enable clipping, commenting, editing and display of short video clips. These clips could be video, streams of text, audio, animations, or computer simulations of the player successes.
When a user believes that they are about to execute gameplay—such as a game character about to attempt a dramatic leap across a ravine—that they feel might be of interest to their friends, the user could tip back the front of their mouse to initiate a signal to start a recording of gameplay at that moment. For example, the accelerometer in the mouse could identify that the mouse was tipped back and then send a signal to the user device (or central controller, or a game controller) requesting that a video be started at that moment. Once the leap across the ravine was successfully completed, the user could again tip back the mouse in order to send a signal indicating that the video recording should be stopped at that moment. The user device (or game controller) could then save the clip and send the clip to the central controller for storage in an account associated with the user unique identifier. There are many ways in which the user could initiate and terminate a gameplay clip. For example, the user might tap the mouse twice to begin recording and three times to end the recording. Another option would be for the user to say “record” into a microphone of the mouse, with software in the mouse capable of speech to text that can translate that verbal request into a ‘start recording’ signal to the user device or game controller. A physical or virtual button on the mouse could also be used to provide start and stop signals for the generation of gameplay clips.
The game controller could also start and stop video recording based on user biometrics. For example, gameplay could be recorded whenever a heart rate sensor of the user's mouse exceeded a particular number of beats per minute. In this way, the player does not have to initiate the creation of the gameplay clips, but rather the clips are recorded whenever the heart rate biometric indicates that the player is in an excited state.
Another way to generate start and stop times for gameplay clips could be via algorithms of the game software that predict that the user is about to do something exciting in the game. For example, the game software might begin to record gameplay whenever a user is involved in a sword fight with a more experienced opponent. After the sword fight was concluded, the game software could ask the user whether or not they wanted a clip of that sword fight to be sent to the user's mouse for storage.
The user could also initiate a clip of gameplay to be recorded, but have the recording end within a particular period of time. For example, the user might set a preference stored in the mouse which indicates that clips should always end three minutes after initiation.
Rather than initiating a gameplay clip to be created as above, the user could initiate a streaming session by having the game software send all gameplay video directly to a video game streaming service such as Twitch. This initiation could be done via a series of taps on the mouse, verbal commands, biometric levels, or algorithmically by the game software.
Rather than creating video clips, the game software could be directed by the user to capture screenshots, audio files, maps of terrain traversed, a list of objects obtained, a list of enemies defeated, etc.
In various embodiments, the user initiates a video clip of his own face as seen through the front facing camera of the user device (e.g., user computer) during gameplay. For example, the user could send an initiation signal (such as taps on a mouse, or two quick blinks while facing the camera) to start a recording of the user's face while engaged in a particularly interesting or exciting activity in-game. Such a video could similarly be sent to the user's mouse for storage, or be sent directly to the central controller for storage in the user's account. This user video could be combined with a clip of the gameplay associated with the game character, and saved as two side-by-side videos synchronized to capture the emotions of the player while showing the exciting gameplay that produced the emotions.
User clips stored in his account at the central controller could allow the user to build a video game highlight reel that could be sent to friends. Such video clips could be listed by game or chronologically. This could be combined with game statistics much like a baseball card. For example, for a game like Fortnite® the player might have several video clips as well as statistical information like the number of games played and the average success rate in those games. For players on teams, statistics and gameplay clips could be cross posted to teammates' pages.
One of the advantages of storage at a central controller is that the user can accumulate videos and statistics across all game platforms and game types.
Device-Assisted Discovery of Social Connections
More than ever, people are searching and engaging in various forms of social connection, both virtually and physically. The mouse and/or keyboard could be devices that applications use to alert a user when a connection is made. The mouse and/or keyboard could be devices that users use to indicate interest in an activity.
In various embodiments, applications alert a user via mouse-keyboard that a connection is made. As a user of an application, I may be interested in a topic or requesting recommendations. Once the request is sent in to various sites (e.g., Pinterest®, Nextdoor™, dating sites, local volunteer organizations, local interests (running club, chess club, gardening club), ebay®), unless the user is routinely checking email, alerts may be missed. The mouse-keyboard could take these alerts and provide feedback that a connection or message has been made. Once notified, a simple mouse-keyboard movement could take a user instantly to the information. For example, a user is interested in getting a recommendation for the best appliance repair person in the area on Nextdoor™. Afterthe request is submitted, the user resumes other activities using their mouse-keyboard. After some time, a recommendation is made. At that point, an alert is sent by Nextdoor™ to the user's mouse-keyboard. The mouse-keyboard could display a color, sound or skin display indicating that a message has been received.
In various embodiments, a user utilizes a mouse-keyboard to respond to connections. A user can respond to the mouse-keyboard indication that a connection is made in various ways. For example, once a user has indication that a message/connection is made via the mouse-keyboard, they can simply click the mouse (or press a key on the keyboard) and the message/action is immediately retrieved from the sending application. This not only provides immediate feedback to the sending application but makes a simple interaction between the user and the application thus creating efficiencies and improved experience. Likewise, in addition to retrieving messages in textual format, a user could open an audio or video channel to instantly connect to the application/other user. This could occur if a person is interested in playing a new game and is seeking an additional player. Once found and the device alerted, the person could communicate directly with the player to establish a time to play. If the response meets the user's needs or the connection is established, another simple click can turn off future alerts from the applications and end the communication.
In various embodiments, a mouse-keyboard assists in making or responding to in-game connections. An in-game player may want some immediate assistance from other players (already in the game or not) on the game overall or a particular section of the game. The user simply selects a mouse-keyboard action and a connection request is made to current and previous players. Once a player determines they want to connect (by selecting the action on the mouse-keyboard), the requesting player is notified on their mouse-keyboard. The connection is made by selecting the mouse-keyboard inputs and assistance is provided via a dedicated audio channel in-game, a textual message or video chat. Once either player decides to end the connection, a simple click on the mouse-keyboard is made.
In-Game Rewards Displayed on Socially-Enabled Peripherals
Game players sometimes gain abilities, levels, titles (like grandmaster, wizard), ratings, (such as a chess or backgammon rating) inventory items (like gold coins, weapons, ammunition, armor, portions, spells, extra lives, etc.) or other benefits achieved during game play. Players also accumulate statistics, such as win rates or accuracy rates. Many players like to show off such achievements, and to let their friends know how much they have achieved.
When a user achieves a level in the game, that level could be displayed on the surface of the user's mouse or keyboard. For example, a display area on the mouse could display that the user was a wizard who had achieved a level 50 of experience. This indication could be displayed whenever the player was using the mouse, or it could be displayed at all times. The user device or game controller could send a signal to the mouse of the achievement level and store it within storage media in the mouse. In another embodiment, the achievement level indication is displayed only when the mouse is not being used or does not have a hand on it. Pressure, temperature, or motion sensors built into the mouse could detect use and automatically turn off the ability level indication. The achievement level display could be an e-ink display which would reduce power consumption requirements.
An achievement level indication could change frequently during a game, such as when a chess player's rating moves up and down after a series of many blitz games with each lasting only a few minutes. The constantly updating rating could be displayed on the mouse display, or it could also be displayed on a keyboard according to various embodiments. For example, the keyboard could have back lighting for each individual key which is capable of causing keys to glow in an order determined by a signal from the user device or game controller. So if the user's new blitz chess rating was 2375, the “2” key would light up and then turn off, followed by the “3” key, then the “7” key, and then finally the “5” key.
Achievement level indicators could also be shared among multiple players. For example, a team of three users could have inventory items of all team members displayed on the mouse of each team member. For example, if player “A” has a Healing Portion, player “B” has a +5 Sword, and player “C” has 35 Gold Pieces, then each of these items would be listed on the display area of the three mice. So player “A” would see “Healing Potion, +5 Sword, and 35 Gold Pieces” displayed on his mouse. These items could be continuously displayed, with updates to the inventory items being sent from the game controller to the mouse whenever an item was added or used. Players could also trigger the display of the inventory items with the click of a button on the mouse, a verbal command to “show inventory”, depressing a function key on the keyboard, or the like.
The mouse could also change its physical shape to reflect changing achievement levels. For example, in a first person shooter game the user's mouse could extend out a small colored plastic plate at the top and bottom of the mouse when the user achieved victory over five opponents in the game. This would allow other users present to see at a glance that the player was doing well, and the extended plates could be positioned to not interfere with ongoing game control via the mouse.
Multiple Controllers, Single Cursor
Devices according to various embodiments could enable multiple users to control a single instance of software. The inputs of individual devices could be communicated to the central controller and then communicated from the central controller to the game controller or software. By allowing multiple users to input into a single piece of software, the devices could enable social game play.
For example, users could swap control of the inputs of a single character, avatar, vehicle, or other aspect of gameplay. Players could swap control voluntarily. Alternatively, the game controller could swap control probabilistically or based upon another dimension, such as relative skill at different aspects of a game, which player has had the least time of control, or which player generates the most excitement for non-controlling players.
Users could control a single input type for a composite character, avatar, vehicle, or other aspect of game play. For example, control of X,Y,Z movement, visual field, and weapon might be controlled by separate players. For example, a player might control the movement of a vehicle such as a ship, while another player might control its ability to shoot.
In various embodiments, one user controls a primary character or entity, and another user controls a sub-entity. For example, a first user controls a mothership, while a second user controls a space probe released by the mothership. As another example, one user controls a main character (e.g., a foot-soldier), while another user controls an assistant, such as a bird or drone that flies overhead and surveys the terrain.
In various embodiments, opponents may take control of one or more functions of input while the device owner might retain other aspects of input. For example, opponents might control the facial expressions of a character, while the device owner retains all other control over the character. As another example, opponents might control the communications (e.g., text or voice messaging) from a character, while the device owner retains all other control of the character. As another example, opponents might control the speed of a character's movement, while the device owner retains control over the direction of the character's movement.
In various embodiments, the central controller might average, select the most popular input, or otherwise combine the input of several users to control aspects of game play. For example, the character's direction of motion may be determined by the direction that was selected by a majority of users having input to the character's actions. As another example, the character's motion may be determined as the vector sum of inputs received from users controlling the character. In various embodiments, all users controlling a character or other game aspect have to agree on an input before some action is taken.
In various embodiments, aspects of control of a character or of other gameplay may not be explicitly communicated to a user. In other words, a user may not always know what effects his inputs will have on a character or on gameplay in general. For example, a user may not know that a particular key on his keyboard controls the speed of a character's trajectory. The user may be left to experiment in order to figure out the effects of his input on character actions or on other aspects of gameplay. In various embodiments, the effects of a particular key (or other input) may change without notice. A user may then be left to figure out what he is now controlling, and what he is no longer controlling.
In various embodiments, two or more users may play a game where one user serves as an instructor while the other user is a student. The instructor may be helping the student learn how to play the game, or to learn how to improve his game play. In various embodiments, the student may be allowed to control a character, vehicle, or other aspect of gameplay. However, when the instructor deems it appropriate, the instructor may assume control and guide the character, vehicle, or other aspect of gameplay. The instructor may thereby help the student with a tricky sequence, with a strategy that had not occurred to the student, with an improved set of motions, or with any other aspect of the game.
Mouse Voting
Teams playing games sometimes require decision making by the group, requiring some discussions between team members.
In various embodiments, game players needing to make a decision could conduct voting protocols through the mice of the players. In this embodiment, a team of five players registers their names with the game controller for communication to the user device and/or the central controller (which can associate the player names with the unique mouse identifiers associated with those player names). The five players then use their mice in gameplay and tap the surface of the mouse three times to initiate a voting protocol. For example, Player #3 might initiate the voting protocol in order to facilitate the group deciding whether or not to cast a spell that would build a bridge over a river. In this example, Player #3 taps her mouse three times quickly and a signal is sent to the user device and then on to the central controller. The central controller then sends a signal out to the mice of all five players, which displays on the surface of those five mice a yes/no option. Each of the five players taps once for ‘yes’, and twice for ‘no’. This selection is communicated back to the central controller, and the option receiving the most votes is then communicated back to be displayed on the surface of each of the five mice.
Many voting protocols could be stored with the central controller, allowing options like giving users the ability to provide greater weights to the votes of more experienced players, or requiring unanimous consent or a two-thirds majority in order to make a decision.
Voting by users could be done anonymously, or the votes could be connected to their real name or game character name.
Mouse to Mouse Communication
Communication between players is very common in game environments, with players often texting each other or calling each other to communicate. This can sometimes be clumsy as players may have to take their hands off of the keyboard or mouse to initiate, manage, or end the communications.
In various embodiments, mice are enabled to communicate directly with each other. For example, a user could triple tap the surface of their mouse to initiate a communication channel with a particular friend, and then speak into a microphone contained within the mouse. That audio signal would then be transmitted to the user device and sent to the user device of the user's friend, and finally sent to the friend's mouse for broadcast via an output speaker in the mouse. In this way, a pair of mice can communicate like a pair of hardwired walkie talkies.
The user could also store a list of the unique mouse identifiers of five of the user's friends, and then initiate a mouse to mouse connection by tapping once on the user's mouse to be connected to the mouse of Friend #1, tapping twice on the mouse to initiate communication with the mouse of Friend #2, etc.
Communication could also be conducted through a microphone within the user's keyboard in a similar manner. The user could say “Friend #3” into the microphone of the keyboard, which would then transmit the signal to the user device, which sends the signal to the user device of Friend #3, which then sends a signal to the speaker built into the keyboard of Friend #3, to thereby enable the direct communication from keyboard to keyboard.
Interactions with Streamers
Streaming platforms such as Twitch®, YouTube® Gaming, and Mixer™ now allow individuals to livestream video game sessions to audiences of thousands or even tens of thousands of fans. While fans can join chat streams with messages of encouragement, there is a need to allow fans to increase the level of interaction with streamers.
In various embodiments, fans of streamers can use their mice to vote for the actions that they want the streamers to take. For example, the streamer could send out a voting prompt to appear on the display screens of the mice of fans, asking them whether the streamer's game character should head North or South. Players then vote by touching the phrase “North” or “South” that is now displayed on their mouse. That signal would go to the user device and then to the central controller, and finally to the controller of the streaming platform to indicate to the streamer what action is requested by the fans.
In another embodiment, fans would be able to provide a direct input into the controls of one or more peripherals used by the streamer. For example, fans could provide input via their mice as to the direction and velocity with which to move over the next 60 seconds of gameplay, with the input from all of those mice combined by the central controller into a single aggregated direction and velocity with which the streamer's game character would be moved for the next 60 seconds.
The ability to subscribe, re-subscribe, donate, or tip small amounts of money would also be facilitated in embodiments where a user's mouse stores value (such as currency) that can be transmitted to the streamer via the central controller.
The streamer could also enable loot boxes, raffles, and giveaways to users that appear on the display screen of a user's mouse. The user's mouse could glow red whenever the streamer was currently streaming.
The user's mouse could include a streamer's insignia or an image of his face on the display screen of a user's mouse.
A streamer could design a custom mouse that included design elements or colors associated with his brand. Such a mouse could include stored preferences including ways for the user to easily connect with the streamer.
Device Changing Shape
While many people work or play games with others remotely, there is a need for increasing the feeling of connection that can help bridge the distance gap.
In various embodiments, the mouse of a user is configured to have a look and feel evocative of a pair of lungs that reflect the actual breathing rate of a second remote user. The rate of breathing can be determined by receiving a breathing rate sensor value from the mouse (or other peripheral capable of determining breathing rate) from the second user, and replicating that breathing rate on the first user's mouse. The breathing effect could be generated by having a soft light glow on and off at a rate equal to the second user's breathing rate. Alternatively, the first user's mouse could have an internal mechanism that allows the mouse to expand on a cadence with the breathing rate. In these embodiments, the breathing rate of the first user could be reflected on the second user's mouse while the second user's breathing rate could be reflected on the first user's mouse. In this way the two users would feel more connected even though they may be thousands of miles apart.
Another way in which the breathing effect could be embodied would be for some or all of the keys of the user's keyboard to be directed to move up and down reflective of the breathing rate of the second user (and vice versa).
The ergonomic shape of peripherals could also change based on the needs of a user. For example, a keyboard could be directed by the user device to incline by a few degrees based on data generated by the user's camera.
Peripherals could also change shape when a user signals that the peripherals are being put away for storage or are being transported to another location. The altered form factor could make the peripherals less likely to sustain damage from being bumped or jostled.
Devices according to various embodiments could include a foldable form-factor in which the devices fold, hinge, or otherwise enclose themselves to protect the device during travel.
Mouse Actions
There are other ways in which a mouse can provide inputs beyond traditional two dimensional plane movements, clicking, and rolling wheels or trackballs.
In various embodiments, the user generates a signal from a mouse by tipping up the front of the mouse, but keeping the rear end of the mouse relatively stationary.
In various embodiments, a mouse may remain fixed or stationary and may interpret mere pressure from different sides as signals to move a mouse pointer. For example, if a person applies pressure to the right side of a stationary mouse (as if moving a mobile mouse to the left), the mouse pointer may move to the left.
A user mouse could also generate a unique signal by turning the mouse over. For example, a user could turn the mouse over to indicate that they were temporarily away from their keyboard, and then turn the mouse back over when they return to gameplay. The game controller could then relate that time away from the keyboard to the other players so that they know the user will be unresponsive during that time.
Connected Devices for Mobile Work
Individuals often use mobile computing devices, such as laptops, tablets, or phones, to conduct work outside of traditional office or home settings. These devices have built-in input devices, and detached keyboards and mice are accessory peripherals. The devices according to various embodiments could improve the functionality of these accessories.
Accessory keyboards and mice are frequently stolen or lost. To prevent theft, a device owner, for example, could set an alarm mode, allowing the owner to leave the device unattended. If the device is touched, the device could be set to produce a loud noise or flash bright colors. In an alarm mode, the device could be set to take a picture if it moved. If the device is connected with another computing device while in alarm mode, it could, for example, trigger the device to send its current GPS coordinates or the IP address of the device to the original owner. For example, to locate a lost device, an individual might enable a “lost device” mode that causes the device to produce a loud noise or cause the device to flash a bright light.
Devices could have additional functionality enabled by geofences or other location-context information, such as the ability to order items and process transactions. For example, a device might recognize that its owner is using it at a cafe and allow the device owner to order a coffee. Prior transactions in the same location might be stored in the memory of the devices for ease of reordering.
Charging devices can be challenging for mobile workers when electrical outlets are scarce or unavailable. Devices according to various embodiments might be able to charge wirelessly from other peripheral devices or from a mobile computing device.
Mobile workers often transport mice and keyboards in purses, backpacks, briefcases, and other bags without putting them in protective cases. Devices according to various embodiments could include a foldable form-factor in which the devices fold, hinge, or otherwise enclose themselves to protect the device during travel.
Parents Playing Games with Kids
Some parents enjoy playing computer games with their kids, but they feel like it would be a better experience if they could more fully participate in the gameplay experience.
One way to improve the shared experience of gameplay would be to have the game allow a single game character to be controlled by two players at the same time. In this way, a parent and child could play a game as one character rather than as competing characters.
Another example would be for the adult to be able to control a parti