While the specification concludes with claims defining the features of embodiments of the invention that are regarded as novel, it is believed that the invention will be better understood from a consideration of the following description in conjunction with the figures, in which like reference numerals are carried forward.
Embodiments herein can be implemented in a wide variety of exemplary ways in various devices such as in personal digital assistants, cellular phones, laptop computers, desktop computers, digital video recorder, electronic inventory devices or scanners and the like. Generally speaking, pursuant to these various embodiments, a method or system herein can further extend the concept of user interfaces that can include wearable computers that act as intelligent agents advising, assisting and guiding users to perform their tasks. A relevant use case for this type of system can for example operate well where a user performs predictable or known tasks, such as courier delivery, maintenance and repairs, quality inspections, logistics, inventory and the like.
With predictable or routine activities, wearable computers can further enhance their functionality by adding support to assist, guide and/or advise the user and even predicts the user's behavior. Such a system can learn, understand and recognize patterns that constitute a user's behavior; then these patterns can be applied to generate a user's context under various embodiments herein. Based on this context, the system can also predict, with some degree of certainty, what the user wants to do next.
When generating user advice, a system 10 as illustrated in
Referring to
The sensors 32 can include a body positioning or tracking sensor 33, a hand positioning or tracking sensor 34, an eye tracking device 35, or a camera module 36. The sensor 32 can provide inputs to a processor 42 such as a smart positioning system. The camera module 36 can also provide input to an image recognition processor 40 before providing input to the processor 42. The hand sensors 34 can detect hand movements and estimate a 3D hand position, a head sensor such as sensor 33 can detect head position and corresponding movements and the eye tracking sensor 35 can detect what the user is looking at or at least the direction or position where the user is looking. The camera module 36 detects the main moving area that the user is looking at and helps to detect those areas with less activity on the user vision field (of the display). Based on user movement and user vision, the system can estimate what might be the best way to present the user interface information to the user.
The system 30 can further include an intelligent agent 38 that can inform the system with hand movement and eye movement prediction based on past data stored in a knowledge base 37. The processor 42 in the form of the smart positioning system can provide inputs 41, 43, 44, 45, or 46 to the processor 50 in the form of a smart UI positioning system. The inputs can help determine the areas that are good or bad for placing visual feedback on the user interface or display. The good and bad areas can also be determined by analyzing high or low contrast areas. For example, a white background or an image of an area having uniformity such as a plain background can be considered a good area. An area that is too bright might be considered a bad area. The inputs can also indicate the body parts that might be interfering on the visual field (e.g., hand position) and where the user eyes are pointing towards. The Smart UI positioning system also gets information from the device configuration 52 (e.g., type of sensors, visual field of the eye wear, type of eye wear, etc.). The application settings 54 can also provide parameters to the processor 50 such as size of output to display, type of information to display (e.g., text, voice, images, etc.). The user might also want to configure where he or she desires the information to be displayed, or recommends the system to stay away from displaying user interface information in certain areas (e.g., low visibility areas).
To make a good decision the system can determine the limits of peripheral vision where the user and device configuration can contribute to calculating the peripheral vision parameters. For example, the type of eye wear device used may limit the peripheral vision parameters. Once the system understands several factors by collecting the data from the distributed sensors, the system 30 can form delineations for appropriate user interface outputs. The factors can include what the peripheral vision parameters are, what the user is currently looking at, what the main activity (and the area of the main activity) are on the user's vision field and where are the user hands and eyes at any given moment. Based on all or a portion of these factors and possibly others, the system can calculate what is a forbidden area 64 and a free area 62 for presenting a user interface output 65 on a screen output 60 as shown in
A background analyzer using pattern recognition can be used to define the best area to place the feedback on the free area for UI. For example, if a whiteboard is on the visible area and away from the user spot, then the positioning system uses the whiteboard area for the feedback. Also, the background analyzer defines where a less crowded area may be or an area further away from any moving object on the background in order to place the feedback optimally for viewing by the user. In contrast,
The image recognition processor 40 of
The intelligent agent 38 of
In another embodiment, if the user utilizes the entire vision field (determined by the user) or the smart agent detects that the entire area is used for the specific task, then the system can suppress a visual user interface output and can optionally opt for an audible output. For example, if the user is using specific eyewear with a small visual field such as infrared goggles, then any visual feedback will interfere. In such an instance, the positioning system can delegate the UI to a multimodal system by blocking the display modality (output). The multimodal component can then, give verbal instructions to the user, or any other type of output modality. Also, if the task requires the user to move, walk, or run (as detected by the movement sensors), any displayed message might be very intrusive and impossible to read. Once again, the modality will adapt to the best output possible.
Referring to
In summary, a system in accordance with the embodiments can perform one or more of the functions of reading distributed sensors around the body and the associated data, understanding a user's movements to selectively identify areas suitable to feed or present the user with visual information and to further decide what type of information to provide the user, understanding where to place (both in terms of device and display area on such device) a UI output, and further selecting the right output (display, speaker, etc.) based on the user's visual field.
Dedicated hardware implementations including, but not limited to, application specific integrated circuits, programmable logic arrays and other hardware devices can likewise be constructed to implement the methods described herein. Applications that may include the apparatus and systems of various embodiments broadly include a variety of electronic and computer systems. Some embodiments implement functions in two or more specific interconnected hardware modules or devices with related control and data signals communicated between and through the modules, or as portions of an application-specific integrated circuit. Thus, the example system is applicable to software, firmware, and hardware implementations.
In accordance with various embodiments of the present invention, the methods described herein are intended for operation as software programs running on a computer processor. Furthermore, software implementations can include, but not limited to, distributed processing or component/object distributed processing, parallel processing, or virtual machine processing can also be constructed to implement the methods described herein.
The present disclosure contemplates a machine readable medium containing instructions, or that which receives and executes instructions from a propagated signal so that a device connected to a network environment can send or receive voice, video or data, and to communicate over the network using the instructions. The instructions may further be transmitted or received over a network via a network interface device.
While the machine-readable medium can be an example embodiment in a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present disclosure. The terms “program,” “software application,” and the like as used herein, are defined as a sequence of instructions designed for execution on a computer system. A program, computer program, or software application may include a subroutine, a function, a procedure, an object method, an object implementation, an executable application, an applet, a servlet, a source code, an object code, a shared library/dynamic load library and/or other sequence of instructions designed for execution on a computer system.
In light of the foregoing description, it should be recognized that embodiments in accordance with the present invention can be realized in hardware, software, or a combination of hardware and software. A network or system according to the present invention can be realized in a centralized fashion in one computer system or processor, or in a distributed fashion where different elements are spread across several interconnected computer systems or processors (such as a microprocessor and a DSP). Any kind of computer system, or other apparatus adapted for carrying out the functions described herein, is suited. A typical combination of hardware and software could be a general purpose computer system with a computer program that, when being loaded and executed, controls the computer system such that it carries out the functions described herein.
In light of the foregoing description, it should also be recognized that embodiments in accordance with the present invention can be realized in numerous configurations contemplated to be within the scope and spirit of the claims. Additionally, the description above is intended by way of example only and is not intended to limit the present invention in any way, except as set forth in the following claims.