The amount of electromagnetic radiation (e.g., light) that a camera photosensor collects and images may depend on the location of objects in the field of view (FOV) of the camera. Briefly, an object that is on the camera's optical axis may appear brighter to the camera's photosensor than an object that is off-axis, other factors being equal. The term “irradiance” generally refers to the electromagnetic radiation that is incident on a surface, such as a photosensor. The terms “radiant exitance” or “radiant emittance” generally refer to electromagnetic radiation that emerges (e.g., reflects) from an object. Irradiance, as well as exitance may be measured per second per unit area. For an object having an angular displacement “θ” relative to the camera's optical axis, the irradiance may, in general, decrease as cos4 θ.
For various applications, it can be advantageous for objects in a scene imaged by a camera to have substantially the same irradiance on the camera photosensor independent of the angular displacement θ. For example, a time of flight (TOF) three-dimensional (3D) camera determines distances to objects in a scene that the camera images by timing how long it takes for light transmitted by the camera to travel to the objects and back to the camera. For some systems, an illumination system transmits the light to the object in very short light pulses. The camera images light that is reflected by the objects and is collected by the photosensor to determine round trip travel times for light. Accurate distance measurement depends on the irradiance associated with the image of the object captured by the photosensor. Moreover, accuracy may improve with increase in the irradiance.
An illumination system having a refractive optical element that compensates for dependence in irradiance of images of objects captured by a photosensor is provided. The irradiance of images of objects having a given exitance may depend on angular displacement from an optical axis. The refractive optical element may be used in an imaging device such as a time-of-flight (TOF) camera. The refractive optical element may structure the light such that similar objects in the same spherical surface in the field of view of the camera have the same irradiance on the camera photosensor.
One embodiment is an illumination system that comprises an image sensor, a light source, and a refractive optical element. The image sensor has a photosensor that captures images of objects in a field of view. The irradiance of images of objects having a given exitance that are captured by the photosensor depends on angular displacement from an optical axis of the image sensor. The refractive optical element receives light from the light source and structures the light to illuminate the field of view to compensate for the dependence of irradiance on angular displacement from the optical axis.
One embodiment is a depth camera system that comprises an image sensor, a light source, a collimator, and a refractive diffuser. The photosensor captures images of objects in a field of view. The collimator collimates light from the light source. The refractive diffuser receives light from the light source and structures the light within the field of view in accordance with 1/cos4 θ, where θ is the angular displacement from an optical axis of the image sensor. The depth camera system also has logic for generating a depth image based on the light received by the photosensor.
One embodiment is a method of generating a depth image that includes the following. Light is refracted onto objects in a field of view using a refractive diffuser. Light that reflects from objects in the field of view is captured at a photosensor having an optical axis. The irradiance of images of objects having a given exitance that are captured by the photosensor depends on angular displacement from the optical axis. Refracting the light includes structuring the light to compensate for the dependence of irradiance on angular displacement from the optical axis. A depth image is generated based on the captured light.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
In the drawings, like-numbered elements correspond to one another.
An illuminator with a refractive optical element is disclosed. The illuminator may be used in, or in conjunction with, a camera or other device having a photosensor. The refractive optical element may be configured to illuminate a camera's field of view (FOV) in a way that compensates for angular displacement related dependence in irradiance of images captured by a photosensor. Specifically, the irradiance of images of objects that have the same exitance may depend on the angular displacement of the objects from the optical axis. In some embodiments, the refractive optical element is a refractive diffuser that structures the light to have an increasing intensity with increasing angular displacement from an optical axis of the camera. The increasing intensity may compensate for the dependence in irradiance on angular displacement.
As with other Figures,
As noted, the irradiance of an object may depend on its position in the FOV. For example, object 15a is depicted on the optical axis 9, whereas object 15b is depicted off axis by approximately the angle θ. However, both are on the spherical surface 11, and are thus the same distance from the camera component 22. If, for the sake of argument, the exitance of object 15a and 15b were the same, then the irradiance of the image of object 15b captured by the photosensor 5 may be significantly less than the irradiance of the image of object 15a. In other words, to the photosensor 5, the image of object 15b would be less intense than the image of object 15a. The irradiance may fall off with angular displacement θ from the optical axis 9. In some cases, the falloff may be about cos4 θ.
A dashed curve 61 representing R(θ)=cos4 θ is shown to the left of spherical FOV imaging surface 11. As noted, the falloff in irradiance may be about cos4 θ, where θ is the angular displacement with respect to the optical axis 9. The label “decreasing irradiance” is meant to represent that the images of the objects captured at the photosensor 5 have a decreasing irradiance away from the optical axis 9. Thus, the decreasing irradiance is referring to the images that the photosensor 5 captures. Therefore, note that the decreasing irradiance is not referring to the exitance of the objects 15 in the FOV.
For various applications it can be advantageous for objects that in fact have the same exitance to have substantially the same irradiance on the camera photosensor independent of the angular displacement from the optical axis 9. For example, a time of flight (TOF) three-dimensional (3D) camera provides distances to features in a scene that the camera images by timing how long it takes light transmitted by the camera to travel to the features and back to the camera. For some techniques the time of the light is actually based on intensity of light, as the following discussion will explain.
To time the travel of the light, the illumination system may transmit a number of very short light pulses into the FOV. These light pulses reflect off from objects 15 and back to the image sensor 26, which captures the light for some period of time. The photosensor 5 may comprise an array of pixels, each of which generates a light intensity value. Each pixel represents a different location in the FOV. The time of flight of the light pulse may then be determined based on the intensity of light at each pixel. Since the time of flight is dependent on light intensity, being able to accurately compensate for dependence of irradiance on angular displacement from the optical axis 9 may allow for much more accurate determinations of distances to objects 15.
Therefore, precision determination of a distance measurement to an object 15 may be dependent on the irradiance associated with the image of the object that the photosensor 5 captures. Moreover, precision determination of a distance measurement may improve with increase in the irradiance. Therefore, being able to illuminate the FOV with a higher intensity of light may improve distance determination.
As the foregoing suggests, for applications of a 3D TOF camera, such as applications involving gesture recognition and/or interfacing a computer with people who are simultaneously interacting in a same computer game running on the computer, it may generally advantageous for objects in a same planar 3 or spherical surface 11 in the FOV of the camera to have a same irradiance on the camera photosensor.
To compensate for dependence in irradiance with angular displacement from the optical axis 9, an illumination system may be configured to increase illumination with increasing angular displacement θ from the optical axis 9. As a result, objects 15 having greater angular displacement from the optical axis 9 may be illuminated with more intense light so that they have greater exitance. As one example, an illuminator could illuminate object 15b with greater light intensity than object 15a to increase the exitance of object 15a. In one embodiment, an illumination system illuminates the camera's FOV with light having intensity substantially proportional to 1/cos4 θ. Thus, the illumination system may compensate for the aforementioned dependence in irradiance that may be proportional to cos4 θ, where θ is the angle of displacement from the optical axis 9. However, note that outside of the FOV, the light intensity may be very low, such that energy is not wasted.
In the embodiment of
Curve 62 represents the intensity of light provided by the illuminator 24. The curve 62 is intended to show that the intensity of light provided by the illuminator 24 increases with increases in angular displacement from the illumination axis 109. For example, the lowest intensity of light within the FOV may be along the illumination axis 109. The light intensity may increase within the FOV with greater angular displacement from the illumination axis 109. Thus, object 15b may be illuminated with greater intensity than object 15a. Therefore, object 15b may have a greater exitance than object 15a, other factors being equal. However, note that outside of the FOV, the light intensity may be quite low, such that energy is not wasted illuminating where it is not needed. As one example, the refractive optical element 40 may have an optical efficiency of about 95%.
Referring again to
Next, some example refractive optical elements 40 will be discussed. In one embodiment, refractive diffuser 40 comprises a pair of lenticular arrays 43.
Referring now to
Referring now to
Note that the lenses 42 are not required to all be the same curvature, size, and/or shape. In some embodiments, the lenses 42 in an array have a variety of different curvatures. Therefore, different lenslets 42 may refract the light to different degrees. In some embodiments, the lenses 42 in an array have a variety of different shapes. For example, some lenslets 42 might be rectangular, others triangular, etc. In some embodiments, the lenses 42 in an array have a variety of the different sizes.
Another possible variation is to reverse the positions of lenticulars 43a, 43b.
The embodiment of
The example refractive optical elements of
As noted above, for applications of a 3D TOF camera, such as applications involving gesture recognition and/or interfacing a computer with people who are simultaneously interacting in a same computer game running on the computer, it may be advantageous for objects in a same planar or spherical surface in the FOV of the camera to have a same irradiance on the camera photosensor.
In some embodiments, the refractive diffuser 40 is used in a motion capture system 10. Motion capture systems obtain data regarding the location and movement of a human body or other subject in a physical space, and can use the data as an input to an application in a computing system. Many applications are possible, such as for military, entertainment, sports and medical purposes. For instance, the motion of humans can be mapped to a three-dimensional (3-D) human skeletal model and used to create an animated character or avatar. Motion capture systems can include optical systems, including those using visible and invisible, e.g., infrared, light, which use cameras to detect the presence of a human in a field of view. Typically, the motion capture system includes an illuminator 24, which illuminates the field of view, and an image sensor which senses light from the field of view to form an image.
The illuminator 24 may structure the light such that the light intensity increases with increasing angular displacement from the optical axis 9. The illuminator 24 may structure the light to compensate for dependence in irradiance on angular displacement, as already discussed. Note that the light intensity may be quite low outside of the FOV 30. In this example, the optical axis 9 is aligned with the image sensor 26. The illuminator 24 may have an illumination axis (not depicted in
In this example, the depth camera system 20, and computing environment 12 provide an application in which an avatar 197 on the display 196 track the movements of the human 8. For example, the avatar may raise an arm when the human raises an arm. The avatar 197 is standing on a road 198 in a 3-D virtual world. A Cartesian world coordinate system may be defined which includes a z-axis which extends along the focal length of the depth camera system 20, e.g., horizontally, a y-axis which extends vertically, and an x-axis which extends laterally and horizontally. Note that the perspective of the drawing is modified as a simplification, as the display 196 extends vertically in the y-axis direction and the z-axis extends out from the depth camera system, perpendicular to the y-axis and the x-axis, and parallel to a ground surface on which the user 8 stands.
Generally, the motion capture system 10 is used to recognize, analyze, and/or track one or more human targets. The computing environment 12 can include a computer, a gaming system or console, or the like, as well as hardware components and/or software components to execute applications.
The depth camera system 20 may include a camera which is used to visually monitor one or more people, such as the human 8, such that gestures and/or movements performed by the human may be captured, analyzed, and tracked to perform one or more controls or actions within an application, such as animating an avatar or on-screen character or selecting a menu item in a user interface (UI).
The motion capture system 10 may be connected to an audiovisual device such as the display 196, e.g., a television, a monitor, a high-definition television (HDTV), or the like, or even a projection on a wall or other surface that provides a visual and audio output to the user. An audio output can also be provided via a separate device. To drive the display, the computing environment 12 may include a video adapter such as a graphics card and/or an audio adapter such as a sound card that provides audiovisual signals associated with an application. The display 196 may be connected to the computing environment 12 via, for example, an S-Video cable, a coaxial cable, an HDMI cable, a DVI cable, a VGA cable, or the like.
The human 8 may be tracked using the depth camera system 20 such that the gestures and/or movements of the user are captured and used to animate an avatar or on-screen character and/or interpreted as input controls to the application being executed by computer environment 12.
Some movements of the human 8 may be interpreted as controls that may correspond to actions other than controlling an avatar. For example, in one embodiment, the player may use movements to end, pause, or save a game, select a level, view high scores, communicate with a friend, and so forth. The player may use movements to select the game or other application from a main user interface, or to otherwise navigate a menu of options. Thus, a full range of motion of the human 8 may be available, used, and analyzed in any suitable manner to interact with an application.
The motion capture system 10 may further be used to interpret target movements as operating system and/or application controls that are outside the realm of games and other applications which are meant for entertainment and leisure. For example, virtually any controllable aspect of an operating system and/or application may be controlled by movements of the human 8.
The depth camera system 20 may include an image camera component 22 that captures the depth image of a scene in a physical space. The depth image may include a two-dimensional (2-D) pixel area of the captured scene, where each pixel in the 2-D pixel area has an associated depth value which represents a linear distance from the image camera component 22, thereby providing a 3-D depth image.
The image camera component 22 may include an illuminator 24, such an infrared (IR) light emitter 24, an image sensor 26, such as an infrared camera, and a red-green-blue (RGB) camera 28 that may be used to capture the depth image of a scene or provide an additional camera for other applications. The illuminator 24 may be configured to compensate for dependence in irradiance of objects captured by the image sensor 26. Thus, the illuminator 24 may have a refractive optical element 40 such as, but not limited to, any of the examples herein.
A 3-D depth camera is formed by the combination of the infrared emitter 24 and the infrared camera 26. For example, in a time-of-flight analysis, the illuminator 24 emits infrared light onto the physical space and the image sensor 26 detects the backscattered light from the surface of one or more targets and objects in the physical space. In some embodiments, pulsed infrared light may be used such that the time between an outgoing light pulse and a corresponding incoming light pulse is measured and used to determine a physical distance from the depth camera system 20 to a particular location on the targets or objects in the physical space. The phase of the outgoing light wave may be compared to the phase of the incoming light wave to determine a phase shift. The phase shift may then be used to determine a physical distance from the depth camera system to a particular location on the targets or objects.
A time-of-flight analysis may also be used to indirectly determine a physical distance from the depth camera system 20 to a particular location on the targets or objects by analyzing the intensity of the reflected beam of light over time via various techniques including, for example, shuttered light pulse imaging.
In another example embodiment, the depth camera system 20 may use a structured light to capture depth information. In such an analysis, patterned light (i.e., light displayed as a known pattern such as grid pattern or a stripe pattern) may be projected onto the scene via, for example, the illuminator 24. Upon striking the surface of one or more targets or objects in the scene, the pattern may become deformed in response. Such a deformation of the pattern may be captured by, for example, the image sensor 26 and/or the RGB camera 28 and may then be analyzed to determine a physical distance from the depth camera system to a particular location on the targets or objects.
The depth camera system 20 may further include a microphone 30 which includes, e.g., a transducer or sensor that receives and converts sound waves into an electrical signal. Additionally, the microphone 30 may be used to receive audio signals such as sounds that are provided by a person to control an application that is run by the computing environment 12. The audio signals can include vocal sounds of the person such as spoken words, whistling, shouts and other utterances as well as non-vocal sounds such as clapping hands or stomping feet.
The depth camera system 20 may include a processor 32 that is in communication with the 3-D depth camera 22. The processor 32 may include a standardized processor, a specialized processor, a microprocessor, or the like that may execute instructions including, for example, instructions for receiving a depth image; generating a grid of voxels based on the depth image; removing a background included in the grid of voxels to isolate one or more voxels associated with a human target; determining a location or position of one or more extremities of the isolated human target; adjusting a model based on the location or position of the one or more extremities, or any other suitable instruction, which will be described in more detail below.
The depth camera system 20 may further include a memory component 34 that may store instructions that are executed by the processor 32, as well as storing images or frames of images captured by the 3-D camera or RGB camera, or any other suitable information, images, or the like. According to an example embodiment, the memory component 34 may include random access memory (RAM), read only memory (ROM), cache, flash memory, a hard disk, or any other suitable tangible computer readable storage component. The memory component 34 may be a separate component in communication with the image capture component 22 and the processor 32 via a bus 21. According to another embodiment, the memory component 34 may be integrated into the processor 32 and/or the image capture component 22.
The depth camera system 20 may be in communication with the computing environment 12 via a communication link 36. The communication link 36 may be a wired and/or a wireless connection. According to one embodiment, the computing environment 12 may provide a clock signal to the depth camera system 20 via the communication link 36 that indicates when to capture image data from the physical space which is in the field of view of the depth camera system 20.
Additionally, the depth camera system 20 may provide the depth information and images captured by, for example, the image sensor 26 and/or the RGB camera 28, and/or a skeletal model that may be generated by the depth camera system 20 to the computing environment 12 via the communication link 36. The computing environment 12 may then use the model, depth information, and captured images to control an application. For example, as shown in
The data captured by the depth camera system 20 in the form of the skeletal model and movements associated with it may be compared to the gesture filters in the gesture library 190 to identify when a user (as represented by the skeletal model) has performed one or more specific movements. Those movements may be associated with various controls of an application.
The computing environment may also include a processor 192 for executing instructions which are stored in a memory 194 to provide audio-video output signals to the display device 196 and to achieve other functionality as described herein.
Step 704 includes capturing light that reflects from objects 15 in the field of view at a photosensor 5. There irradiance of images of objects captured by the photosensor 5 may depend based on angular displacement. As noted herein, if two objects have the same exitance, the irradiance of the image of the object that is further from the optical axis may be lower. As noted, step 702 may structure the light to compensate for this dependence in irradiance on angular displacement. In some embodiments, step 704 includes capturing reflections of the IR pulses for some pre-determined time period. For example, the photosensor 5 may be shuttered, such that it is allowed to collect light for some pre-determined time period and blocked from receiving light for some pre-determined time period.
Step 706 includes generating a depth image based on the captured light. The depth image may contain depth values (e.g., distances to objects in the FOV). The depth image may include a two-dimensional (2-D) pixel area of the captured scene, where each pixel in the 2-D pixel area has an associated depth value which represents either a linear distance from the image camera component 22 (radial distance) or the Z component of the 3D location viewed by the pixel (perpendicular distance). In some embodiments, step 706 includes analyzing brightness values of each pixel of the photosensor 5. Since the refractive optical element 40 compensates for the angular displacement related dependence in irradiance, the determination of the depth image is improved.
A graphics processing unit (GPU) 108 and a video encoder/video codec (coder/decoder) 114 form a video processing pipeline for high speed and high resolution graphics processing. Data is carried from the graphics processing unit 108 to the video encoder/video codec 114 via a bus. The video processing pipeline outputs data to an A/V (audio/video) port 140 for transmission to a television or other display. A memory controller 110 is connected to the GPU 108 to facilitate processor access to various types of memory 112, such as RAM (Random Access Memory).
The multimedia console 100 includes an I/O controller 120, a system management controller 122, an audio processing unit 123, a network interface 124, a first USB host controller 126, a second USB controller 128 and a front panel I/O subassembly 130 that are preferably implemented on a module 118. The USB controllers 126 and 128 serve as hosts for peripheral controllers 142(1)-142(2), a wireless adapter 148, and an external memory device 146 (e.g., flash memory, external CD/DVD ROM drive, removable media, etc.). The network interface (NW IF) 124 and/or wireless adapter 148 provide access to a network (e.g., the Internet, home network, etc.) and may be any of a wide variety of various wired or wireless adapter components including an Ethernet card, a modem, a Bluetooth module, a cable modem, and the like.
System memory 143 is provided to store application data that is loaded during the boot process. A media drive 144 is provided and may comprise a DVD/CD drive, hard drive, or other removable media drive. The media drive 144 may be internal or external to the multimedia console 100. Application data may be accessed via the media drive 144 for execution, playback, etc. by the multimedia console 100. The media drive 144 is connected to the I/O controller 120 via a bus, such as a Serial ATA bus or other high speed connection.
The system management controller 122 provides a variety of service functions related to assuring availability of the multimedia console 100. The audio processing unit 123 and an audio codec 132 form a corresponding audio processing pipeline with high fidelity and stereo processing. Audio data is carried between the audio processing unit 123 and the audio codec 132 via a communication link. The audio processing pipeline outputs data to the A/V port 140 for reproduction by an external audio player or device having audio capabilities.
The front panel I/O subassembly 130 supports the functionality of the power button 150 and the eject button 152, as well as any LEDs (light emitting diodes) or other indicators exposed on the outer surface of the multimedia console 100. A system power supply module 136 provides power to the components of the multimedia console 100. A fan 138 cools the circuitry within the multimedia console 100.
The CPU 101, GPU 108, memory controller 110, and various other components within the multimedia console 100 are interconnected via one or more buses, including serial and parallel buses, a memory bus, a peripheral bus, and a processor or local bus using any of a variety of bus architectures.
When the multimedia console 100 is powered on, application data may be loaded from the system memory 143 into memory 112 and/or caches 102, 104 and executed on the CPU 101. The application may present a graphical user interface that provides a consistent user experience when navigating to different media types available on the multimedia console 100. In operation, applications and/or other media contained within the media drive 144 may be launched or played from the media drive 144 to provide additional functionalities to the multimedia console 100.
The multimedia console 100 may be operated as a standalone system by simply connecting the system to a television or other display. In this standalone mode, the multimedia console 100 allows one or more users to interact with the system, watch movies, or listen to music. However, with the integration of broadband connectivity made available through the network interface 124 or the wireless adapter 148, the multimedia console 100 may further be operated as a participant in a larger network community.
When the multimedia console 100 is powered on, a specified amount of hardware resources are reserved for system use by the multimedia console operating system. These resources may include a reservation of memory (e.g., 16 MB), CPU and GPU cycles (e.g., 5%), networking bandwidth (e.g., 8 kbs), etc. Because these resources are reserved at system boot time, the reserved resources do not exist from the application's view.
In particular, the memory reservation preferably is large enough to contain the launch kernel, concurrent system applications and drivers. The CPU reservation is preferably constant such that if the reserved CPU usage is not used by the system applications, an idle thread will consume any unused cycles.
With regard to the GPU reservation, lightweight messages generated by the system applications (e.g., popups) are displayed by using a GPU interrupt to schedule code to render popup into an overlay. The amount of memory required for an overlay depends on the overlay area size and the overlay preferably scales with screen resolution. Where a full user interface is used by the concurrent system application, it is preferable to use a resolution independent of application resolution. A scaler may be used to set this resolution such that the need to change frequency and cause a TV resynch is eliminated.
After the multimedia console 100 boots and system resources are reserved, concurrent system applications execute to provide system functionalities. The system functionalities are encapsulated in a set of system applications that execute within the reserved system resources described above. The operating system kernel identifies threads that are system application threads versus gaming application threads. The system applications are preferably scheduled to run on the CPU 101 at predetermined times and intervals in order to provide a consistent system resource view to the application. The scheduling is to minimize cache disruption for the gaming application running on the console.
When a concurrent system application requires audio, audio processing is scheduled asynchronously to the gaming application due to time sensitivity. A multimedia console application manager (described below) controls the gaming application audio level (e.g., mute, attenuate) when system applications are active.
Input devices (e.g., controllers 142(1) and 142(2)) are shared by gaming applications and system applications. The input devices are not reserved resources, but are to be switched between system applications and the gaming application such that each will have a focus of the device. The application manager preferably controls the switching of input stream, without knowledge the gaming application's knowledge and a driver maintains state information regarding focus switches. The console 100 may receive additional inputs from the depth camera system 20 of
The computer 241 may also include other removable/non-removable, volatile/nonvolatile computer storage media, e.g., a hard disk drive 238 that reads from or writes to non-removable, nonvolatile magnetic media, a magnetic disk drive 239 that reads from or writes to a removable, nonvolatile magnetic disk 254, and an optical disk drive 240 that reads from or writes to a removable, nonvolatile optical disk 253 such as a CD ROM or other optical media. Other removable/non-removable, volatile/nonvolatile tangible computer readable storage media that can be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The hard disk drive 238 is typically connected to the system bus 221 through an non-removable memory interface such as interface 234, and magnetic disk drive 239 and optical disk drive 240 are typically connected to the system bus 221 by a removable memory interface, such as interface 235.
The drives and their associated computer storage media discussed above and depicted in
The computer 241 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 246. The remote computer 246 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 241, although only a memory storage device 247 has been depicted in
When used in a LAN networking environment, the computer 241 is connected to the LAN 245 through a network interface or adapter 237. When used in a WAN networking environment, the computer 241 typically includes a modem 250 or other means for establishing communications over the WAN 249, such as the Internet. The modem 250, which may be internal or external, may be connected to the system bus 221 via the user input interface 236, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 241, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
The foregoing detailed description of the technology herein has been presented for purposes of illustration and description. It is not intended to be exhaustive or to limit the technology to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. The described embodiments were chosen to best explain the principles of the technology and its practical application to thereby enable others skilled in the art to best utilize the technology in various embodiments and with various modifications as are suited to the particular use contemplated. It is intended that the scope of the technology be defined by the claims appended hereto.
Number | Name | Date | Kind |
---|---|---|---|
4445774 | Spinelli et al. | May 1984 | A |
4627620 | Yang | Dec 1986 | A |
4630910 | Ross et al. | Dec 1986 | A |
4641964 | Mitani et al. | Feb 1987 | A |
4645458 | Williams | Feb 1987 | A |
4647144 | Finkel | Mar 1987 | A |
4695953 | Blair et al. | Sep 1987 | A |
4702475 | Elstein et al. | Oct 1987 | A |
4711543 | Blair et al. | Dec 1987 | A |
4751642 | Silva et al. | Jun 1988 | A |
4796997 | Svetkoff et al. | Jan 1989 | A |
4809065 | Harris et al. | Feb 1989 | A |
4817950 | Goo | Apr 1989 | A |
4843568 | Krueger et al. | Jun 1989 | A |
4893183 | Nayar | Jan 1990 | A |
4901362 | Terzian | Feb 1990 | A |
4925189 | Braeunig | May 1990 | A |
5101444 | Wilson et al. | Mar 1992 | A |
5148154 | MacKay et al. | Sep 1992 | A |
5184295 | Mann | Feb 1993 | A |
5229754 | Aoki et al. | Jul 1993 | A |
5229756 | Kosugi et al. | Jul 1993 | A |
5239463 | Blair et al. | Aug 1993 | A |
5239464 | Blair et al. | Aug 1993 | A |
5288078 | Capper et al. | Feb 1994 | A |
5295491 | Gevins | Mar 1994 | A |
5320538 | Baum | Jun 1994 | A |
5347306 | Nitta | Sep 1994 | A |
5385519 | Hsu et al. | Jan 1995 | A |
5405152 | Katanics et al. | Apr 1995 | A |
5417210 | Funda et al. | May 1995 | A |
5423554 | Davis | Jun 1995 | A |
5454043 | Freeman | Sep 1995 | A |
5469740 | French et al. | Nov 1995 | A |
5495576 | Ritchey | Feb 1996 | A |
5516105 | Eisenbrey et al. | May 1996 | A |
5524637 | Erickson et al. | Jun 1996 | A |
5534917 | MacDougall | Jul 1996 | A |
5563988 | Maes et al. | Oct 1996 | A |
5577981 | Jarvik | Nov 1996 | A |
5580249 | Jacobsen et al. | Dec 1996 | A |
5594469 | Freeman et al. | Jan 1997 | A |
5597309 | Riess | Jan 1997 | A |
5616078 | Oh | Apr 1997 | A |
5617312 | Iura et al. | Apr 1997 | A |
5638300 | Johnson | Jun 1997 | A |
5641288 | Zaenglein | Jun 1997 | A |
5682196 | Freeman | Oct 1997 | A |
5682229 | Wangler | Oct 1997 | A |
5690582 | Ulrich et al. | Nov 1997 | A |
5703367 | Hashimoto et al. | Dec 1997 | A |
5704837 | Iwasaki et al. | Jan 1998 | A |
5715834 | Bergamasco et al. | Feb 1998 | A |
5818528 | Roth et al. | Oct 1998 | A |
5875108 | Hoffberg et al. | Feb 1999 | A |
5877803 | Wee et al. | Mar 1999 | A |
5913727 | Ahdoot | Jun 1999 | A |
5933125 | Fernie | Aug 1999 | A |
5980256 | Carmein | Nov 1999 | A |
5989157 | Walton | Nov 1999 | A |
5995649 | Marugame | Nov 1999 | A |
6005548 | Latypov et al. | Dec 1999 | A |
6009210 | Kang | Dec 1999 | A |
6054991 | Crane et al. | Apr 2000 | A |
6066075 | Poulton | May 2000 | A |
6072494 | Nguyen | Jun 2000 | A |
6073489 | French et al. | Jun 2000 | A |
6077201 | Cheng et al. | Jun 2000 | A |
6098458 | French et al. | Aug 2000 | A |
6100896 | Strohecker et al. | Aug 2000 | A |
6101289 | Kellner | Aug 2000 | A |
6128003 | Smith et al. | Oct 2000 | A |
6130677 | Kunz | Oct 2000 | A |
6141463 | Covell et al. | Oct 2000 | A |
6147678 | Kumar et al. | Nov 2000 | A |
6152856 | Studor et al. | Nov 2000 | A |
6159100 | Smith | Dec 2000 | A |
6173066 | Peurach et al. | Jan 2001 | B1 |
6181343 | Lyons | Jan 2001 | B1 |
6188777 | Darrell et al. | Feb 2001 | B1 |
6215890 | Matsuo et al. | Apr 2001 | B1 |
6215898 | Woodfill et al. | Apr 2001 | B1 |
6226396 | Marugame | May 2001 | B1 |
6229913 | Nayar et al. | May 2001 | B1 |
6256033 | Nguyen | Jul 2001 | B1 |
6256400 | Takata et al. | Jul 2001 | B1 |
6283860 | Lyons et al. | Sep 2001 | B1 |
6289112 | Jain et al. | Sep 2001 | B1 |
6299308 | Voronka et al. | Oct 2001 | B1 |
6308565 | French et al. | Oct 2001 | B1 |
6316934 | Amorai-Moriya et al. | Nov 2001 | B1 |
6363160 | Bradski et al. | Mar 2002 | B1 |
6384819 | Hunter | May 2002 | B1 |
6411744 | Edwards | Jun 2002 | B1 |
6430997 | French et al. | Aug 2002 | B1 |
6476834 | Doval et al. | Nov 2002 | B1 |
6496598 | Harman | Dec 2002 | B1 |
6503195 | Keller et al. | Jan 2003 | B1 |
6539931 | Trajkovic et al. | Apr 2003 | B2 |
6570555 | Prevost et al. | May 2003 | B1 |
6633294 | Rosenthal et al. | Oct 2003 | B1 |
6640202 | Dietz et al. | Oct 2003 | B1 |
6661918 | Gordon et al. | Dec 2003 | B1 |
6681031 | Cohen et al. | Jan 2004 | B2 |
6714665 | Hanna et al. | Mar 2004 | B1 |
6731799 | Sun et al. | May 2004 | B1 |
6738066 | Nguyen | May 2004 | B1 |
6765726 | French et al. | Jul 2004 | B2 |
6788809 | Grzeszczuk et al. | Sep 2004 | B1 |
6801637 | Voronka et al. | Oct 2004 | B2 |
6859326 | Sales | Feb 2005 | B2 |
6873723 | Aucsmith et al. | Mar 2005 | B1 |
6876496 | French et al. | Apr 2005 | B2 |
6900946 | Koehler | May 2005 | B2 |
6937742 | Roberts et al. | Aug 2005 | B2 |
6950534 | Cohen et al. | Sep 2005 | B2 |
6963445 | Hoover et al. | Nov 2005 | B2 |
7003134 | Covell et al. | Feb 2006 | B1 |
7033736 | Morris et al. | Apr 2006 | B2 |
7036094 | Cohen et al. | Apr 2006 | B1 |
7038855 | French et al. | May 2006 | B2 |
7039676 | Day et al. | May 2006 | B1 |
7042440 | Pryor et al. | May 2006 | B2 |
7050606 | Paul et al. | May 2006 | B2 |
7057814 | Boyd et al. | Jun 2006 | B2 |
7058204 | Hildreth et al. | Jun 2006 | B2 |
7060957 | Lange et al. | Jun 2006 | B2 |
7113918 | Ahmad et al. | Sep 2006 | B1 |
7121946 | Paul et al. | Oct 2006 | B2 |
7170492 | Bell | Jan 2007 | B2 |
7184048 | Hunter | Feb 2007 | B2 |
7202898 | Braun et al. | Apr 2007 | B1 |
7222078 | Abelow | May 2007 | B2 |
7227526 | Hildreth et al. | Jun 2007 | B2 |
7259747 | Bell | Aug 2007 | B2 |
7308112 | Fujimura et al. | Dec 2007 | B2 |
7317836 | Fujimura et al. | Jan 2008 | B2 |
7348963 | Bell | Mar 2008 | B2 |
7359121 | French et al. | Apr 2008 | B2 |
7367887 | Watabe et al. | May 2008 | B2 |
7372977 | Fujimura et al. | May 2008 | B2 |
7379563 | Shamaie | May 2008 | B2 |
7379566 | Hildreth | May 2008 | B2 |
7389591 | Jaiswal et al. | Jun 2008 | B2 |
7412077 | Li et al. | Aug 2008 | B2 |
7421093 | Hildreth et al. | Sep 2008 | B2 |
7428856 | Podkopayev | Sep 2008 | B2 |
7430312 | Gu | Sep 2008 | B2 |
7436496 | Kawahito | Oct 2008 | B2 |
7450736 | Yang et al. | Nov 2008 | B2 |
7452275 | Kuraishi | Nov 2008 | B2 |
7460690 | Cohen et al. | Dec 2008 | B2 |
7489812 | Fox et al. | Feb 2009 | B2 |
7513668 | Peng et al. | Apr 2009 | B1 |
7536032 | Bell | May 2009 | B2 |
7555142 | Hildreth et al. | Jun 2009 | B2 |
7560701 | Oggier et al. | Jul 2009 | B2 |
7570805 | Gu | Aug 2009 | B2 |
7574020 | Shamaie | Aug 2009 | B2 |
7576727 | Bell | Aug 2009 | B2 |
7590262 | Fujimura et al. | Sep 2009 | B2 |
7593552 | Higaki et al. | Sep 2009 | B2 |
7598942 | Underkoffler et al. | Oct 2009 | B2 |
7607509 | Schmiz et al. | Oct 2009 | B2 |
7620202 | Fujimura et al. | Nov 2009 | B2 |
7668340 | Cohen et al. | Feb 2010 | B2 |
7680298 | Roberts et al. | Mar 2010 | B2 |
7683954 | Ichikawa et al. | Mar 2010 | B2 |
7684592 | Paul et al. | Mar 2010 | B2 |
7701439 | Hillis et al. | Apr 2010 | B2 |
7702130 | Im et al. | Apr 2010 | B2 |
7704135 | Harrison, Jr. | Apr 2010 | B2 |
7710391 | Bell et al. | May 2010 | B2 |
7729530 | Antonov et al. | Jun 2010 | B2 |
7746345 | Hunter | Jun 2010 | B2 |
7760182 | Ahmad et al. | Jul 2010 | B2 |
7767949 | Perlman et al. | Aug 2010 | B2 |
7809167 | Bell | Oct 2010 | B2 |
7812304 | Ikeda et al. | Oct 2010 | B2 |
7834846 | Bell | Nov 2010 | B1 |
7852262 | Namineni et al. | Dec 2010 | B2 |
RE42256 | Edwards | Mar 2011 | E |
7898522 | Hildreth et al. | Mar 2011 | B2 |
8031906 | Fujimura et al. | Oct 2011 | B2 |
8035612 | Bell et al. | Oct 2011 | B2 |
8035614 | Bell et al. | Oct 2011 | B2 |
8035624 | Bell et al. | Oct 2011 | B2 |
8072470 | Marks | Dec 2011 | B2 |
20030029917 | Hennick et al. | Feb 2003 | A1 |
20040257669 | Koehler | Dec 2004 | A1 |
20050031166 | Fujimura et al. | Feb 2005 | A1 |
20050058337 | Fujimura et al. | Mar 2005 | A1 |
20060157640 | Perlman et al. | Jul 2006 | A1 |
20070086176 | Kanade et al. | Apr 2007 | A1 |
20080026838 | Dunstan et al. | Jan 2008 | A1 |
20080043466 | Chakmakjian et al. | Feb 2008 | A1 |
20080062424 | Shires et al. | Mar 2008 | A1 |
20080212836 | Fujimura et al. | Sep 2008 | A1 |
20090167922 | Perlman et al. | Jul 2009 | A1 |
20100034427 | Fujimura et al. | Feb 2010 | A1 |
20100220212 | Perlman et al. | Sep 2010 | A1 |
20100238526 | Baxter et al. | Sep 2010 | A1 |
20100253810 | Povlick et al. | Oct 2010 | A1 |
20110115885 | Wernersson | May 2011 | A1 |
20120193517 | Zickler et al. | Aug 2012 | A1 |
Number | Date | Country |
---|---|---|
101142806 | Mar 2008 | CN |
101254344 | Jun 2010 | CN |
0583061 | Feb 1994 | EP |
08044490 | Feb 1996 | JP |
9310708 | Jun 1993 | WO |
9717598 | May 1997 | WO |
9944698 | Sep 1999 | WO |
Entry |
---|
Sales, Tasso R.M. “Efficient and uniform illumination with microlens-based band-limited diffusers”. Photonics Spectra [online], Apr. 12, 2010, [retrieved on Dec. 22, 2010], 4 pages, Retrieved from the Internet: <URL:http://www.photonics.com/Article.aspx?AID=41972>, Laurin Publishing: Pittsfield, MA, USA. |
Kanade et al., “A Stereo Machine for Video-rate Dense Depth Mapping and Its New Applications”, IEEE Computer Society Conference on Computer Vision and Pattern Recognition, 1996, pp. 196-202,The Robotics Institute, Carnegie Mellon University, Pittsburgh, PA. |
Miyagawa et al., “CCD-Based Range Finding Sensor”, Oct. 1997, pp. 1648-1652, vol. 44 No. 10, IEEE Transactions on Electron Devices. |
Rosenhahn et al., “Automatic Human Model Generation”, 2005, pp. 41-48, University of Auckland (CITR), New Zealand. |
Aggarwal et al., “Human Motion Analysis: A Review”, IEEE Nonrigid and Articulated Motion Workshop, 1997, University of Texas at Austin, Austin, TX. |
Shao et al., “An Open System Architecture for a Multimedia and Multimodal User Interface”, Aug. 24, 1998, Japanese Society for Rehabilitation of Persons with Disabilities (JSRPD), Japan. |
Kohler, “Special Topics of Gesture Recognition Applied in Intelligent Home Environments”, In Proceedings of the Gesture Workshop, 1998, pp. 285-296, Germany. |
Kohler, “Vision Based Remote Control in Intelligent Home Environments”, University of Erlangen-Nuremberg/Germany, 1996, pp. 147-154, Germany. |
Kohler, “Technical Details and Ergonomical Aspects of Gesture Recognition applied in Intelligent Home Environments”, 1997, Germany. |
Hasegawa et al., “Human-Scale Haptic Interaction with a Reactive Virtual Human in a Real-Time Physics Simulator”, Jul. 2006, vol. 4, No. 3, Article 6C, ACM Computers in Entertainment, New York, NY. |
Qian et al., “A Gesture-Driven Multimodal Interactive Dance System”, Jun. 2004, pp. 1579-1582, IEEE International Conference on Multimedia and Expo (ICME), Taipei, Taiwan. |
Zhao, “Dressed Human Modeling, Detection, and Parts Localization”, 2001, The Robotics Institute, Carnegie Mellon University, Pittsburgh, PA. |
He, “Generation of Human Body Models”, Apr. 2005, University of Auckland, New Zealand. |
Isard et al., “CONDENSATION—Conditional Density Propagation for Visual Tracking”, 1998, pp. 5-28, International Journal of Computer Vision 29(1), Netherlands. |
Livingston, “Vision-based Tracking with Dynamic Structured Light for Video See-through Augmented Reality”, 1998, University of North Carolina at Chapel Hill, North Carolina, USA. |
Wren et al., “Pfinder: Real-Time Tracking of the Human Body”, MIT Media Laboratory Perceptual Computing Section Technical Report No. 353, Jul. 1997, vol. 19, No. 7, pp. 780-785, IEEE Transactions on Pattern Analysis and Machine Intelligence, Caimbridge, MA. |
Breen et al., “Interactive Occlusion and Collision of Real and Virtual Objects in Augmented Reality”, Technical Report ECRC-95-02, 1995, European Computer-Industry Research Center GmbH, Munich, Germany. |
Freeman et al., “Television Control by Hand Gestures”, Dec. 1994, Mitsubishi Electric Research Laboratories, TR94-24, Caimbridge, MA. |
Hongo et al., “Focus of Attention for Face and Hand Gesture Recognition Using Multiple Cameras”, Mar. 2000, pp. 156-161, 4th IEEE International Conference on Automatic Face and Gesture Recognition, Grenoble, France. |
Pavlovic et al., “Visual Interpretation of Hand Gestures for Human-Computer Interaction: A Review”, Jul. 1997, pp. 677-695, vol. 19, No. 7, IEEE Transactions on Pattern Analysis and Machine Intelligence. |
Azarbayejani et al., “Visually Controlled Graphics”, Jun. 1993, vol. 15, No. 6, IEEE Transactions on Pattern Analysis and Machine Intelligence. |
Granieri et al., “Simulating Humans in VR”, The British Computer Society, Oct. 1994, Academic Press. |
Brogan et al., “Dynamically Simulated Characters in Virtual Environments”, Sep./Oct. 1998, pp. 2-13, vol. 18, Issue 5, IEEE Computer Graphics and Applications. |
Fisher et al., “Virtual Environment Display System”, ACM Workshop on Interactive 3D Graphics, Oct. 1986, Chapel Hill, NC. |
“Virtual High Anxiety”, Tech Update, Aug. 1995, pp. 22. |
Sheridan et al., “Virtual Reality Check”, Technology Review, Oct. 1993, pp. 22-28, vol. 96, No. 7. |
Stevens, “Flights into Virtual Reality Treating Real World Disorders”, The Washington Post, Mar. 27, 1995, Science Psychology, 2 pages. |
“Simulation and Training”, 1994, Division Incorporated. |
English Machine-translation of Japanese Publication No. JP08-044490 published on Feb. 16, 1996. |
Chinese Office Action dated Nov. 4, 2015, Chinese Patent Application No. 201210056397.7. |
Response to Office Action dated Mar. 21, 2016, Chinese Patent Application No. 2012100563977. |
English translation of the Amended Claims (Marked-up Version) filed in Response to Office Action dated Mar. 21, 2016, Chinese Patent Application No. 2012100563977. |
Notice on Grant of Patent Right for Invention and Granted Claims dated May 17, 2016, Chinese Patent Application No. 201210056397.7. |
Number | Date | Country | |
---|---|---|---|
20120229611 A1 | Sep 2012 | US |