1. Field of the Invention
The present invention generally relates to interactive media. More specifically, the present invention relates to providing a display using a three-dimensional vision system.
2. Background Art
Traditionally, human interaction with video display systems has required users to employ devices such as hand-held remote controls, keyboards, mice, and joystick controls. An interactive video display system allows real-time, human interaction with images generated and displayed by the system without employing such devices.
While existing interactive video display systems allow real-time, human interactions, such displays are limited in many ways. In one example, the existing interactive video systems require specialized hardware to be held by the users. The specialized hardware may be inconvenient and prone to damage or loss. Further, the specialized hardware may require frequent battery replacement. Specialized hardware, too, may provide a limited number of points to be tracked by the existing interactive video systems, thus limiting the usefulness and reliability in interacting with the entire body of a user or with multiple users.
In another example, the existing interactive video systems are camera-based, such as the EyeToy® from Sony Computer Entertainment Inc. Certain existing camera-based interactive video systems may be limited in the range of motions of the user that can be tracked. Additionally, some camera-based systems only allow for body parts that are moving to be tracked rather than the entire body. In some instances, distance information may not be detected (i.e., the system may not provide for depth perception).
An interactive video display system allows a physical object to interact with a virtual object. A light source delivers a pattern of invisible light to a three-dimensional space occupied by the physical object. A camera detects invisible light scattered by the physical object. A computer system analyzes information generated by the camera, maps the position of the physical object in the three-dimensional space, and generates a responsive image that includes the virtual object. A display presents the responsive image.
The display 105 may include a variety of components. The display 105 may be a flat panel display such as a liquid-crystal display (LCD), a plasma screen, an organic light emitting diode (OLED) display screen, or other display that is flat. The display 105 may include a cathode ray tube (CRT), an electronic ink screen, a rear projection display, a front projection display, an off-axis front (or rear) projector (e.g., the WT600 projector sold by NEC), a screen that produces a 3D image (e.g., a lenticular 3D video screen), or a fogscreen. (e.g., the Heliodisplay™ screen made by 102 technologies). The display 105 may include multiple screens or monitors that may be tiled to form a single larger display. The display 105 may be non-planar (e.g., cylindrical or spherical).
The 3D vision system 110 may include a stereo vision system to combine information generated from two or more cameras (e.g., a stereo camera) to construct a three-dimensional image. The functionality of the stereo vision system may be analogous to depth perception in humans resulting from binocular vision. The stereo vision system may input two or more images of the same physical object taken from slightly different angles into the computing device 120.
The computing device 120 may process the inputted images using techniques that implement stereo algorithms such as the Marr-Poggio algorithm. The stereo algorithms may be utilized to locate features such as texture patches from corresponding images of the physical object acquired simultaneously at slightly different angles by the stereo vision system. The located texture patches may correspond to the same part of the physical object. The disparity between the positions of the texture patches in the images may allow the distance from the camera to the part of the physical object that corresponds to the texture patch to be determined by the computing device 120. The texture patch may be assigned position information in three dimensions.
Some examples of commercially available stereo vision systems include the Tyzx DeepSea™ and the Point Grey Bumblebee™. The stereo vision systems may include cameras that are monochromatic (e.g., black and white) or polychromatic (e.g., “color”). The cameras may be sensitive to one or more specific bands of the electromagnetic spectrum, including visible light (i.e., light having wavelengths approximately within the range from 400 nanometers to 700 nanometers), infrared light (i.e., light having wavelengths approximately within the range from 700 nanometers to 1 millimeter), and ultraviolet light (i.e., light having wavelengths approximately within the range from 10 nanometers to 400 nanometers).
Texture patches may act as “landmarks” used by the computing device implemented stereo algorithm to correlate two or more images. The reliability of the stereo algorithm may therefore be reduced when applied to images of physical objects having large areas of uniformities such as color and texture. The reliability of the stereo algorithm-specifically distance determinations—may be enhanced, however, by illuminating a physical object being imaged by the stereo vision system with a pattern of light. The pattern of light may be supplied by a light source such as the light source 115.
The 3D vision system 110 may include a time-of-flight camera capable of obtaining distance information for each pixel of an acquired image. The distance information for each pixel may correspond to the distance from the time-of-flight camera to the object imaged by that pixel. The time-of-flight camera may obtain the distance information by measuring the time required for a pulse of light to travel from a light source proximate to the time-of-flight camera to the object being imaged and back to the time-of-flight camera. The light source may repeatedly emit light pulses allowing the time-of-flight camera to have a frame-rate similar to a standard video camera. For example, the time-of-flight camera may have a distance range of approximately 1-2 meters at 30 frames per second. The distance range may be increased by reducing the frame-rate and increasing the exposure time. Commercially available time-of-flight cameras include those available from manufacturers such as Canesta Inc. of Sunnyvale, Calif. and 3DV Systems of Israel.
The 3D vision system 110 may also include one or more of a laser rangefinder, a camera paired with a structured light projector, a laser scanner, a laser line scanner, an ultrasonic imager, or a system capable of obtaining three-dimensional information based on the intersection of foreground images from multiple cameras. Any number of 3D vision systems, which may be similar to 3D vision system 110, may be simultaneously used. Information generated by the several 3D vision systems may be merged to create a unified data set.
The light source 115 may deliver light to the physical space imaged by the 3D vision system 110. Light source 115 may include a light source that emits visible and/or invisible light (e.g., infrared light). The light source 115 may include an optical filter such as an absorptive filter, a dichroic filter, a monochromatic filter, an infrared filter, an ultraviolet filter, a neutral density filter, a long-pass filter, a short-pass filter, a band-pass filter, or a polarizer. Light source 115 may rapidly be turned on and off to effectuate a strobing effect. The light source 115 may be synchronized with the 3D vision system 110 via a wired or wireless connection.
Light source 115 may deliver a pattern of light to the physical space that is imaged by the 3D vision system 110. A variety of patterns may be used in the pattern of light. The pattern of light may improve the prominence of the texture patterns in images acquired by the 3D vision system 110, thus increasing the reliability of the stereo algorithms applied to the images by the computing device 120. The pattern of light may be invisible to users (e.g., infrared light). A pattern of invisible light may allow the interactive video display system 100 to operate under any lighting conditions in the visible spectrum including complete or near darkness. The light source 115 may illuminate the physical space being imaged by the 3D vision system 110 with un-patterned visible light when background illumination is insufficient for the user's comfort or preference.
The light source 115 may include concentrated light sources such as high-power light-emitting diodes (LEDs), incandescent bulbs, halogen bulbs, metal halide bulbs, or arc lamps. A number of concentrated light sources may be simultaneously used. Any number of concentrated light sources may be grouped together or spatially dispersed. A substantially collimated light source (e.g., a lamp with a parabolic reflector and one or more narrow angle LEDs) may be included in the light source 115.
Various patterns of light may be used to provide prominent texture patches to the physical object being imaged by the 3D vision system 110; for example, a random dot pattern. Other examples include a fractal noise pattern that provides noise on varying length scales or a set of parallel lines that are separated by randomly varying distances.
The patterns in the pattern of light may be generated by the light source 115, which may include a video projector. The video projectors may be designed to project an image that is provided via a video input cable or some other input mechanism. The projected image may change over time to facilitate the performance of the 3D vision system 110. In one example, the projected image may dim in an area that corresponds to a part of the image acquired by the 3D vision system 110 that is becoming saturated. In another example, the projected image may exhibit higher resolution in those areas where the physical object is close to the 3D vision system 110. Any number of video projectors may simultaneously be used.
Light source 115 may include a structured light projector. The structured light projector may cast out a static or dynamic pattern of light. Examples of a structured light projector include the LCD-640™ and the MiniRot-H1™ that are both available from ABW.
Computing device 120 in
The analysis performed by the computing device 120 may further include coordinate transformation (e.g., mapping) between position information in physical space and position information in virtual space. The position information in virtual space may be confined by predefined boundaries. In one example, the predefined boundaries are established to encompass only the portion of the virtual space presented by the display 105, such that the computing device 120 may avoid performing analyses on position information in the virtual space that will not be presented. The analysis may refine the position information by removing portions of the position information that are located outside a predefined space, smoothing noise in the position information, and removing spurious points in the position information.
The computing device 120 may create and/or generate virtual objects that do not necessarily correspond to the physical objects imaged by the 3D vision system 110. For example, user 130 of
In the form factor 515 as illustrated in
In the form factor 525 shown in
The 3D vision system 110 and/or the light source 115 may be mounted to a monitor of a laptop computer. The monitor may replace the display 105 in such an embodiment while the laptop computer may replace the computing device 120 as otherwise illustrated in
The interactive video display system 100 may further include audio components such as a microphone and/or a speaker. The audio components may enhance the user's interaction with the virtual space by supplying, for example, music or sound-effects that are correlated to certain interactions. The audio components may also facilitate verbal communication with other users. The microphone may be directional to better capture audio from specific users without excessive background noise. In another example, the speaker may be directional to focus audio onto specific users and specific areas. A directional speaker may be commercially available from manufacturers, such as Brown Innovations (e.g., the Maestro™ and the SoloSphere™), Dakota Audio, Holosonics, and the American Technology Corporation of San Diego (ATCSD).
The virtual space, which may be defined in part by the coordinate space grid 820, may be presented to the users 805 and 810 on the display 105. The virtual space may appear to the users 805 and 810 as if the objects in the virtual space (e.g., the virtual user representations 825 and 830 of the users 805 and 810, respectively) are behind the display 105. In some embodiments, such as that shown in
Additionally, the coordinate space grid 815 may not intersect the surface on which the users 805 and 810 are positioned. This may ensure that the feet of the virtual user representations of the users do not appear above a virtual floor. The virtual floor may be perceived by the users as the bottom of the display.
The virtual space observed by the users 805 and 810 may vary based on which type of display is chosen. The display 105 may be capable of presenting images such that the images appear three-dimensional to the users 805 and 810. The users 805 and 810 may perceive the virtual space as a three-dimensional environment. Users may determine three-dimensional position information of the respective virtual user representations 825 and 830 as well as that of other virtual objects. The display 105 may, in some instances, not be capable of portraying three-dimensional position information to the users 805 and 810, in which case the depth component of the virtual user representations 825 and 830 may be ignored or rendered into a two-dimensional image.
Mapping may be performed between the coordinate space grid 815 in the physical space to the coordinate space grid 820 in the virtual space such that the display 105 behaves similar to a mirror as perceived by the users 805 and 810. Motions of the virtual user representation 825 may be presented as mirrored motions of the user 805. The mapping may be calibrated such that, when the user 805 touches or approaches the display 105, the virtual user representation 825 touches or approaches the same part of the display 105. Alternatively, the mapping may be performed such that the virtual user representation 825 may appear to recede from the display 105 as the user 805 approaches the display 105. The user 805 may perceive the virtual user representation 825 as facing away from the user 805.
The coordinate system may be assigned arbitrarily to the physical space and/or the virtual space, which may provide for various interactive experiences. In one such interactive experience, the relative sizes of two virtual user representations may be altered compared to the relative sizes of two users in that the taller user may be represented by the shorter virtual user representation. A coordinate space grid in the physical space may be orthogonal, thus not skewed as illustrated by the coordinate space grid 815 in
In
Information (including a responsive image or data related thereto) from one or more interactive video display systems, each similar to the interactive video display system 100, may be shared over a network or a high-speed data connection.
The principles illustrated by
Many applications of the interactive video display system 100 exist involving various types of interactions. Additionally, a variety of virtual objects, other than virtual user representations, may be presented by a display, such as the display 105. Two-dimensional force-based interactions and influence-image-based interactions are described in U.S. Pat. No. 7,259,747 entitled “Interactive Video Display System,” filed May 28, 2002, which is hereby incorporated by reference.
Two-dimensional force-based interactions and influence-image-based interactions may be extended to three dimensions. Thus, the position information in three dimensions of a user may be used to generate a three-dimensional influence-image to affect the motion of a three-dimensional object. These interactions, in both two dimensions and three dimensions, allow the strength and direction of a force imparted by the user on a virtual object to be computed, giving the user control over how the motion of the virtual object affected.
Users may interact with the virtual objects by intersecting with the virtual objects in the virtual space. The intersection may be calculated in three dimensions. Alternatively, the position information in three dimensions of the user may be projected to two dimensions and calculated as a two-dimensional intersection.
Visual effects may be generated based at least on the position information in three dimensions of the user. In some examples, a glow, a warping, an emission of particles, a flame trail, or other visual effects may be generated using the position information in three dimensions of the user or of a portion of the user. The visual effects may be based on the position of specific body parts of the user. For example, the user may create virtual fireballs by bringing the hands of the user together.
The users may use specific gestures (e.g., pointing, waving, grasping, pushing, grabbing, dragging and dropping, poking, drawing shapes using a finger, and pinching) to pick up, drop, move, rotate, or manipulate otherwise the virtual objects presented on the display. This feature may allow for many applications. In one example, the user may participate in a sports simulation in which the user may box, play tennis (using a virtual or physical racket), throw virtual balls, etc. The user may engage in the sports simulation with other users and/or virtual participants. In another example, the user may navigate virtual environments in which the user may use natural body motions (e.g., leaning) to move about in the virtual environments.
The user may, in some instances, interact with virtual characters. In one example, the virtual character presented on the display may talk, play, and otherwise interact with users as they pass by the display. The virtual character may be computer controlled or may be controlled by a human at a remote location.
The interactive video display system 100 may be used in a wide variety of advertising applications. Some examples of the advertising applications may include interactive product demonstrations and interactive brand experiences. In one example, the user may virtually try on clothes by dressing the virtual user representation of the user.
The elements, components, and functions described herein may be comprised of instructions that are stored on a computer-readable storage medium. The instructions may be retrieved and executed by a processor (e.g., a processor included in the computing device 120). Some examples of instructions are software, program code, and firmware. Some examples of storage medium are memory devices, tape, disks, integrated circuits, and servers. The instructions are operational when executed by the processor to direct the processor to operate in accord with the invention. Those skilled in the art are familiar with instructions, processor(s), and storage media.
Software may perform a variety of tasks to improve the usefulness of the interactive video display system 100. In embodiments where multiple 3D vision systems (e.g., the 3D vision system 110) are used, the position information may be merged by the software into one coordinate system (e.g., coordinate space grids 1120 and 1140). In one example, one of the multiple 3D vision systems may focus on the physical space near to the display while another of the multiple 3D vision systems may focus on the physical space far from the display. Alternately, the two of the multiple 3D vision systems may cover a similar portion of the physical space from two different angles.
In embodiments in which the 3D vision system 110 includes the stereo camera discussed herein, the quality and resolution of the position information generated by the stereo camera may be processed variably. In one example, the portion of the physical space that is closest to the display may be processed at a higher resolution in order to resolve individual fingers of the user. Resolving the individual fingers may increase accuracy for various gestural interactions.
Several methods, which may be described by the software, may be used to remove portions of the position information (e.g., inaccuracies, spurious points, and noise). In one example, background methods may be used to mask out the position information from areas of the 3D vision system 110 field of view that are known to have not moved for a particular period of time. The background methods (also referred to as background subtraction methods) may be adaptive, allowing the background methods to adjust to changes in the position information over time. The background methods may use luminance, chrominance, and/or distance data generated by the 3D vision system 110 in order to distinguish a foreground from a background. Once the foreground is determined, the position information gathered from outside the foreground region may be removed. In another example, noise filtering methods may be applied directly to the position information or be applied as the position information is generated by the 3D vision system 110. The noise filtering methods may include smoothing and averaging techniques (e.g., median filtering). A mentioned herein, spurious points (e.g., isolated points and small clusters of points) may be removed from the position information when, for example, the spurious points do not correspond to a virtual object. In one embodiment, in which the 3D vision system 110 includes a color camera, chrominance information may be obtained of the user and other physical objects. The chrominance information may be used to provide a color, three-dimensional virtual user representation that portrays the likeness of the user. The color, three-dimensional virtual user representation may be recognized, tracked, and/or displayed on the display.
The position information may be analyzed with a variety of methods. The analysis may be directed by the software. Physical objects, such as body parts of the user (e.g., fingertips, fingers, and hands), may be identified in the position information. Various methods for identifying the physical objects may include shape recognition and object recognition algorithms. The physical objects may be segmented using any combination of two/three-dimensional spatial, temporal, chrominance, or luminance information. Furthermore, the physical objects may be segmented under various linear or non-linear transformations of information, such as two/three-dimensional spatial, temporal, chrominance, or luminance information. Some examples of the object recognition algorithms may include deformable template matching, Hough transforms, and algorithms that aggregate spatially contiguous pixels/voxels in an appropriately transformed space.
The position information of the user may be clustered and labeled by the software, such that the cluster of points corresponding to the user is identified. Additionally, the body parts of the user (e.g., the head and the arms) may be segmented as markers. The position information may be dustered using unsupervised methods such as k-means and hierarchical dustering. A feature extraction routine and a feature classification routine may be applied to the position information. The feature extraction routine and the feature classification routine are not limited to use with the position information and may also be applied to any previous feature extraction or feature classification in any of the information generated.
A virtual skeletal model may be mapped to the position information of the user. The virtual skeletal model may be mapped via a variety of methods that may include expectation maximization, gradient descent, particle filtering, and feature tracking. Additionally, face recognition algorithms (e.g., eigenface and fisherface) may be applied to the information generated by the 3D vision system 110 in order to identify a specific user and/or facial expressions of the user. The facial recognition algorithms may be applied to image-based or video-based information. Characteristic information about the user (e.g., face, gender, identity, race, and facial expression) may be determined and affect content presented by the display.
The 3D vision system 110 may be specially configured to detect certain physical objects other than the user. In one example, RFID tags attach to the physical objects may be detected by a RFID reader to provide or generate position information of the physical objects. In another example a light source attached to the object may blink in a specific patter to provide identifying information to the 3D vision system 110.
As mentioned herein, the virtual user representation may be presented by a display (e.g., the display 105) in a variety of ways. The virtual user representation may be useful in allowing the user to interact with the virtual objects presented by the display. In one example, the virtual user representation may mimic a shadow of the user. The shadow may represent a projection onto a flat surface of the position information of the user in 3D.
In a similar example, the virtual user representation may include an outline of the user, such as may be defined by the edges of the shadow. The virtual user representation, as well as other virtual objects, may be colored, highlighted, rendered, or otherwise processed arbitrarily before being presented by the display. Images, icons, or other virtual renderings may represent the hands or other body parts of the users. A virtual representation of, for example, the hand of the user may only appear on the display under certain conditions (e.g., when the hand is pointed at the display). Features may be added to the virtual user representation that does not necessarily correspond to the user. In one example, a virtual helmet may be included in the virtual user representation of a user not wearing a physical helmet.
The virtual user representation may change appearance based on the user's interactions with the virtual objects. In one example, the virtual user representation may be shown as a gray shadow and not be able to interact with virtual objects. As the virtual objects come within a certain distance of the virtual user representation, the grey shadow may change to a color shadow and the user may begin to interact with the virtual objects.
The embodiments discussed herein are illustrative. Various modifications or adaptations of the methods and/or specific structures described may become apparent to those skilled in the art. The breadth and scope of a preferred embodiment should not be limited by any of the above-described exemplary embodiments.
The present application claims the priority benefit of U.S. provisional patent application No. 60/922,873 filed Apr. 10, 2007 and entitled “Display Using a Three-Dimensional Vision System,” the disclosure of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
60922873 | Apr 2007 | US |