in machine learning, a decision tree is the result of a resource-intensive process by which a computing system processes a very large set of examples. These examples are used to construct a tree of questions that are used to ultimately classify input data at runtime. The more examples that are used during training of a decision tree, typically, the more accurate the runtime result. Traditionally the solution for processing millions to billions of examples is to use large clusters of networked central processing unit (CPU) based computing devices. However, this type of solution is expensive and is subject to unreliability. For example, additional components and connections are required in order to network clusters of CPU-based computing devices together, which create additional points of potential failure. Moreover, since the CPU-based computing device clusters are typically distributed over different areas, additional labor is required to maintain the clusters, which increases operating costs.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed 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. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
Various embodiments are disclosed herein that relate to generating a decision tree through graphical processing unit (GPU) based machine learning. For example, one disclosed embodiment provides a method for generating a decision tree including a plurality of nodes organized into levels. The decision tree is generated by a parallel processing pipeline including a plurality of processing blocks. Each processing block includes a plurality of graphics processing units (GPUs) sharing a memory block. Additionally, each GPU of the parallel processing pipeline shares a global memory. The method includes, for each level of the decision tree: performing, at each GPU of the parallel processing pipeline, a feature test for a feature in a feature set on every example in an example set. The method further includes accumulating, at each memory block, a result of each feature test performed on each example processed by the plurality of GPUs that share the memory block. The method further includes writing the accumulated results from each memory block to the global memory to generate a histogram of features for every node in the level, and for each node in the level, assigning a feature having a lowest entropy in accordance with the histograms to the node.
The present description is directed to machine learning for decision tree training. More particularly, the present description is directed to leveraging a parallel processing pipeline including a plurality of graphics processing units (GPUs) to generate a decision tree. For example, heavier operations or operations that collectively take up a large portion of time for machine learning may be performed in parallel by the parallel processing pipeline. Moreover, examples having a shared attribute, such as pixels selected from the same image, may be processed in parallel by GPUs within a processing block of the parallel processing pipeline in order to leverage local memory shared by GPUs of the processing block. In particular, results of feature tests performed on the examples may be accumulated in the localized memory before writing the accumulated results to global memory. By accumulating feature test results in faster local memory before writing the accumulated results to slower global memory, a number of global memory write operations may be reduced. Correspondingly, decision tree training time may be significantly reduced.
Furthermore, in some applications, a GPU-based parallel processing pipeline may be implemented in a localized or non-distributed platform that enables decision tree training to be performed by a single machine for a fraction of the cost and with greater reliability than a distributed CPU-based computing device cluster. In one particular example, decision free training, is performed on a single relatively inexpensive machine rather than a large expensive cluster of machines in a remote data center that is very difficult to debug when there are problems. However it is to be understood that one or more GPU-based parallel processing pipelines may be implemented in a distributed or networked device cluster configuration without departing from the scope of this disclosure.
The computing system 100 includes a logic subsystem 102, a data-holding subsystem 104, a display subsystem 106, and an input subsystem 108. The computing system 100 may optionally include other components not shown in
The logic subsystem 102 may include one or more physical devices configured to execute one or more instructions. For example, the logic subsystem may be configured to execute one or more instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs. Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more devices, or otherwise arrive at a desired result. In one example, the logic subsystem 102 is configured to execute instructions included in a computer program product.
The logic subsystem 102 may include one or more central processing units (CPUs) 110. that are configured to execute software instructions. In the illustrated embodiment the CPU 110 includes multicore processors 112 that share a local memory cache 114. For example, the local memory cache 114 may include L1 cache L2 cache, etc. The local memory cache 114 may be connected to a main or global memory 116. The local memory cache 114 and the global memory 116 may be included in the data-holding subsystem 104. It is to be understood that the CPU 110 may include a single core without departing from the scope of this disclosure. In one example, the CPU 110 includes 12 cores that execute 24 threads, and the 12 cores share 24 gigabytes (GBs) of random access memory (RAM).
The logic subsystem 102 may include a parallel processing pipeline 118. The parallel processing pipeline 118 may include a plurality of processing blocks 120. Each of the plurality of processing blocks 120 may include a plurality of graphic processing units (GPUs) 122. In some embodiments the GPUs may take the form of general processing graphic processing units (GPGPUs). Each of the plurality of GPUs 122 may share a local memory block 124. In other words, a local memory block may be associated with each processing blocks.
Furthermore, each of the plurality of processing blocks may share the global memory 116. The plurality of local memory blocks 124 and the global memory 116 may be included in the data-holding subsystem 104. In one example, the parallel processing pipeline 118 includes 960 GPUs, each local memory block may be 16 kilobytes (KB), and the global memory may include 16 GBs of RAM. Additionally or alternatively, the logic subsystem may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions.
The data holding, subsystem 104 may include one or more physical, non-transitory, devices configured to hold data and/or instructions executable by the logic subsystem to implement the herein described methods and processes. When such methods and processes are implemented, the state of data-holding subsystem 104 may be transformed (e.g., to hold different data). In contrast, in some embodiments aspects of the instructions described herein may be propagated in a transitory fashion by a pure signal (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for at least a finite duration. Furthermore, data and/or other forms of information pertaining to the present disclosure may be propagated by a pure signal.
The data-holding subsystem 104 may include removable media and/or built-in devices. The data-holding subsystem 104 may include optical memory devices (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory devices (e.g., RAM, EPROM, EEPROM, etc.) and/or magnetic memory devices (e.g., hard disk drive, floppy disk drive, tape drive, MRAM, etc.), among others. The data-holding subsystem 104 may include removable computer-readable storage media, which may be used to store and/or transfer data and/or instructions executable to implement the herein described methods and processes. Removable computer-readable storage media may take the form of CDs, DVDs, HD-DVDs, Blu-Ray Discs, EEPROMs, and/or floppy disks, among others. The data-holding subsystem 104 may include devices with one or more of the following characteristics: volatile, nonvolatile, dynamic, static, read/write, read-only, random access, sequential access, location addressable, file addressable, and content addressable. In some embodiments, logic subsystem 102 and data-holding subsystem 104 may be integrated into one or more common devices, such as an application specific integrated circuit or a system on a chip.
The terms “module,” “program,” and “engine” may be used to describe an aspect of computing system 100 that is implemented to perform one or more particular functions. In some cases, such a module, program, or engine may be instantiated via logic subsystem 102 executing instructions held by data-holding subsystem 104. It is to be understood that different modules, programs, and/or engines may be instantiated from the same application, service, code block, object, library, routine, API, function, etc. Likewise, the same module, program, and/or engine may be instantiated by different applications, services, code blocks, objects, routines, APIs, functions, etc. The terms “module,” “program,” and “engine” are meant to encompass individual or groups of executable files, data files, libraries, drivers, scripts, database records, etc.
The data-holding subsystem 104 may include a decision tree training program 126 configured to perform machine learning operations to generate a decision tree 152. The decision tree training program 126 may include an input signal boost module 128 and a training module 130.
The input signal boost module 128 may be configured to modify source data 132 to provide an example set 146 of examples suitable for the training module 130 to generate the decision tree 152. It is to be understood that the example set 146 may include any suitable set of example data to train the decision tree 152 without departing from the scope of this disclosure. Additionally or alternatively, the input signal boost module 128 may be configured to boost particular scenarios defined by the source data 132 so that machine learning operations performed by the training module 130 can better identify the scenarios to generate a more effective decision tree. The input signal boost module 128 may be configured to receive source data 132 and boost input from the input subsystem 108.
The input subsystem 108 may include a sensing device 144 configured to sense position and orientation of one or more objects. In one example, the sensing device 144 includes a red, green, blue (RGB) camera and a depth sensor to sense a position and orientation of an object. Additionally or alternatively, the input subsystem 108 may include user input devices such as keyboards, mice, game controllers, cameras, microphones, and/or touch screens, for example.
It is to be understood that the source data 132 may include any suitable data to convey a set of different examples that may be processed by the training module 130 to generate the decision tree 152. In one example, the source data 132 includes a plurality of depth maps 134. The plurality of depth maps 134 may include different poses of characters that may be used to generate a decision tree that classifies body parts. The boost input 142 may represent user instructions to modify the depth maps 134 to increase the likelihood of scenarios where body parts of characters are accurately classified by the decision tree 152.
The boost module 128 may be configured to retarget each of depth maps 134 for different motions, poses, body types, heights, weights, colors, etc. to provide a retargeted depth map set 136 including a plurality of retargeted depth maps 138 that increase the number of different examples in the example set 146. Further, the boost module 128 may be configured to separate each of depth maps 134 into layered Object planes 140, in particular, each object may be in a different plane, and the different planes may be layered on each other to create the retargeted depth maps 138.
The boost module 128 may be configured to modify the retargeted depth maps 138 to add/remove object planes based on the boost input 142. The boost input 142 may be provided by the input subsystem 108 in response to reviewing the output data 154 that is output by the decision tree 152. Accordingly, the boost input 142 and the output data 154 may act in conjunction to provide feedback to the decision tree training program 126 to improve the effectiveness of decision tree training by increasing a signal strength of a scenario so that it is more likely to be identified by the decision tree 152. In an example of a manual implementation, a user may review the output data 154 and may provide the boost input 142 to manually select object planes 140 be added to or removed from the retargeted depth maps 138. In an example of an automated implementation, the output data 154 may be provided as a database including a signal strength of an example, and in response to the signal strength being less than a signal strength threshold, the boost input 142 may be provided to the boost module 128.
When included, the display subsystem 106 may be used to present a visual representation of data held by data-holding subsystem 104, such as the retargeted depth maps 138. In one example, a user views the retargeted depth maps 138 to identify which object planes 140 are to be added/removed to boost the signal strength of a scenario. As the herein described methods and processes change the data held by the data-holding subsystem 104, and thus transform the state of the data-holding subsystem 104, the state of display subsystem 106 may likewise be transformed to visually represent changes in the underlying data. The display subsystem 106 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic subsystem 102 and/or data-holding subsystem 104 in a shared enclosure, or such display devices may be peripheral display devices.
Continuing with
The training module 130 may include a learn kernel 150 configured to receive the example set and the feature set 148. The learn kernel 150 may be configured to control the parallel processing pipeline 118 to process each example in the example set 146 in parallel by performing a feature test of selected features in the feature set 148 for every node in the decision tree 152. In particular, the boost module 128 may be configured to perform, at each GPU 122 of the parallel processing pipeline 118, a feature test for a feature in the feature set 148 on an example selected from the example set 146. Collectively, the GPUs 122 of the parallel processing pipeline 118 perform a feature test for selected features in the feature set 148 on every example in the example set 146 for every node in the decision tree 152. In some embodiments, the features may be chosen at random from the feature set. Parallel processing may be performed on a per-level basis, where for each level of the decision tree 152, every node is assigned a feature before moving to the next level.
As an example, a feature test may include a point depth feature test where two pixels are selected from a depth map, and an arithmetic operation (e.g., subtraction) is performed to determine a value that is compared to a threshold. If the value is greater than the threshold, the feature test returns a “true” value. If the value is less than the threshold, the feature test returns a “false” value.
The learn kernel 150 may be configured to accumulate a result of each feature test performed on each example in the local memory blocks 124. Feature tests performed by GPUs 122 in the same processing block 120 may be accumulated in a local memory block 124 shared by the GPUs of the processing block 120. In one example, each example includes a pixel selected from one of a plurality of depth maps, and the example set includes pixels from each of the plurality of depth maps. Further, pixels selected as examples from the same depth map are processed by GPUs of the same processing block. This may facilitate reduced processing overhead that, in turn reduces the training time of the decision tree 152. It is to be understood that an example pixel for decision tree training may be selected from any suitable two dimensional image. Non-limiting examples of images that may include example pixels for decision tree training may include RGB, silhouettes, etc. Moreover, three dimensional volumes may be included in a decision tree training example set. Non-limiting examples of three dimensional volumes include medical imaging (e.g., magnetic resonance imaging), video sequences, etc.
Upon accumulation of the feature test results in the local memory blocks 124, the learn kernel 150 may be configured to write the accumulated results from each memory block 124 to the global memory 116 to generate a histogram of features for every node in a level of the decision tree 152. Feature-test results may be accumulated in local memory blocks before being written to global memory in order to reduce the number of atomic increments to global memory in order to reduced decision tree training time. Moreover, time to write to shared local memory may be, for example an order of magnitude faster than writing to global memory. As such, decision tree training time may be further reduced, in this manner.
The learn kernel 150 may be configured to determine the entropy or any other suitable optimization criterion of each feature in the histograms for each node. As another example, a twoing optimization routine may be applied to each feature. Further the learn kernel 150 may be configured to find the most optimal feature for the node or assign a feature having a lowest entropy in accordance with the histograms to the node. The learn kernel 150 may be configured to assign a feature to each node in a level before processing nodes in other levels. The learn kernel 150 may be configured to recursively assign features to nodes in each level till every node in every level of the tree is assigned a feature to train or generate the decision tree 152.
A block of example pseudo-code configuring the learn kernel 150 to assign a feature to a node that may be performed recursively to train the decision tree 152 is provided:
The Learn function may be recursively performed for every node to generate the decision tree 152. The Learn function includes two nested for loops that cause a ComputeResponse function to perform a feature test for a feature “f” an example “e.” The inner for loop invokes the ComputeResponse function to performs a feature test for a feature on every example in an example set “s.” If the ComputeResponse function returns a “true” value, the positive[e.Class] list is iterated, if the ComputeResponse function returns a “false” value, the negative[e.Class] is iterated. Accordingly, positive and negative histograms (lists) of features are generated for every example. Note in some cases the iterations may be replaced by atomic adds to reduce memory access wait time.
The outer for loop repeats the inner for loop for selected feature in a feature set. Accordingly, the ComputeResponse function performs a feature test for selected features in the feature set on every example in the example set. Due to the nested for loops, the ComputeResponse function and the list iterations are performed repeatedly. Such repetition may be leveraged by the parallel processing pipeline. In particular, each GPU may perform a feature test on every example in parallel, so that the positive and negative histograms for every example are generated at the same time.
The InfoGain function calculates a purity level for each feature in the positive and negative histograms. The InfoGain function produces a value that is the opposite of entropy. For example, as entropy decreases, the InfoGain value increases, and the purity of the result increases. The ScoreFeature function determines the feature having the highest InfoGain value or lowest entropy and assigns that feature to the node. The SplitExamples function splits the example set into two example sets according to the positive and negative histograms. The two example sets are iteratively learned to assign features having the lowest entropy to create child nodes. The Learn function is performed iteratively to generate the decision tree 152. Note that the pseudo-code block is one example and other code blocks may be implemented. As one example, the for loop functions could be switched so that the loop over examples could be outside of the loop over features.
In the illustrated example, the boost module 128 identifies five different object planes that can be layered together to form the depth map 200. The first object plane is the closest plane or has the shallowest depth and includes a first person in a standing position. The second object plane is farther or has a deeper depth than the first plane and includes a second person in a sitting position. The third plane is farther or has a deeper depth than the second plane and includes a couch on which the second person in the second object plane is sitting. The fourth object plane is farther or has a deeper depth than the third object plane and includes a first wall. The fifth object plane is farther or has a deeper depth than the fourth object plane and includes a second wall.
Upon receiving output data from a generated decision tree, the boost module 128 may remove the first object layer from the depth map since the first person occludes the second person. This feedback may boost signal strength of the second object plane so that body parts of the second person are more likely to be identified and accurately classified by the decision tree after being trained with the depth maps as modified by the boost module 128.
By accumulating feature test results in the local memory blocks 124, a number of write operations to the global memory 116 may be reduced. In particular, atomic add operations may be performed to write the accumulated feature test results from the local memory blocks 124 to the global memory 116 instead of performing an atomic increment operation for each feature test result in this example, four feature test results are in contention for portion 1 (counted 0-5) of the positive list of the local memory block 124. The four test results are accumulated through four atomic increment operations. Subsequently, the accumulated feature test results are written from the local memory block 124 to the global memory 116 via an atomic add 318 that adds a value of 4 to the global memory 116. Using the optimized strategy in this example, fourteen atomic increments and two non-atomic increments are performed to accumulate the feature test results in the local memory block and seven atomic add operations are performed to write the accumulated feature test results from the shared memory block to the global memory. In contrast, the non-optimized strategy performed sixteen atomic add operations to write the feature test results to global memory.
At 504, the method may include accumulating, at each memory block, a result of each feature test performed on each example processed by the plurality of GPUs that share the memory block. In one example, pixel examples selected from the same depth map are processed by GPUs of the same processing block so that the feature test results are accumulated to the same local memory block, if a plurality of feature test results is in contention for the same portion of the memory block, at 506, the method may include performing an atomic increment to a portion of the memory block to accumulate each feature test result to the memory portion. The atomic increment locks the memory portion for each feature test result so that the accumulated value is not corrupted by attempts to accumulate the other feature test results to the memory portion. If one feature test result is to be stored in the portion of the memory block, at 508 the method may include performing a non-atomic increment to a portion of the memory block.
At 510, the method may include writing the accumulated results from each local memory block to the global memory to generate a histogram of features for every node in the level. At 512, in some cases where more than one feature test result is accumulated to the same memory portion of the local memory block, the method may include performing an atomic add to the global memory for each portion of the memory block that includes an accumulated feature test result value.
At 514, the method may include for each node in the level, assigning a feature having a lowest entropy in accordance with the histograms to the node. Due to the parallel processing of the feature tests and creation of the histograms for each node, each node in a level may be trained or assigned a feature in parallel.
At 516, the method may include determining if every level in the decision tree has been trained or generated. In other words, it may be determined if every node in every level been assigned a feature. If it is determined the every level of the decision tree has been generated or trained, the method returns to other operations. Otherwise, the method moves to 518.
At 518, the method may include traversing to the next level of the tree. Upon going to the next level the method returns to 502 to train every node in the next level in parallel. This is carried out recursively till every node in every level of the decision tree is trained or generated.
At 602, the method may include generating a decision tree from an example set. In some cases, at 604, the method may include generating a decision tree from an example set that includes pixel examples that are selected from depth images that include a plurality of layered object planes.
At 606, the method may include determining if a signal strength of any scenarios in the depth maps are low. In one example, determining signal strength includes determining that the entropy for a scenario is greater than an entropy threshold. If it is determined that the signal strength is low the method moves to 608. Otherwise, the method returns to other operations.
At 608, the method may include modifying the example set to boost signal strength of scenarios with low signal strength. In cases where the example set includes pixels selected from depth maps that include a plurality of layered object planes, at 610, the method may include modifying the depth maps to add or remove an object plane to boost the signal strength of an object in the depth image. Furthermore, the method may return to 602 to train the decision tree based on the modified example set. The method may continue until the signal strength of the scenarios represented by the example set have been boosted to a suitable level
It is to be understood that the configurations and/or approaches described herein are exemplary in nature, and that these specific embodiments or examples are not to be considered in a limiting sense, because numerous variations are possible. The specific routines or methods described herein may represent one or more of any number of processing strategies. As such, various acts illustrated may be performed in the sequence illustrated, in other sequences, in parallel, or in some cases omitted. Likewise, the order of the above-described processes may be changed.
The subject matter of the present disclosure includes all novel and nonobvious combinations and subcombinations of the various processes, systems and configurations, and other features, functions, acts, and/or properties disclosed herein, as well as any and all equivalents thereof.
Number | Name | Date | Kind |
---|---|---|---|
4288078 | Lugo | Sep 1981 | A |
4627620 | Yang | Dec 1986 | A |
4630910 | Ross et al. | Dec 1986 | A |
4645458 | Williams | Feb 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 | 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, Jr. | 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 |
5774591 | Black et al. | Jun 1998 | A |
5875108 | Hoffberg et al. | Feb 1999 | A |
5877803 | Wee et al. | Mar 1999 | A |
5913727 | Ahdoot | Jun 1999 | A |
5933125 | Fernie et al. | 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 | 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 |
6289122 | Karidi | 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 |
6721444 | Gu et al. | Apr 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 |
6873723 | Aucsmith et al. | Mar 2005 | B1 |
6876496 | French et al. | Apr 2005 | B2 |
6937742 | Roberts et al. | Aug 2005 | B2 |
6950534 | Cohen et al. | Sep 2005 | B2 |
7003134 | Covell et al. | Feb 2006 | B1 |
7007035 | Kamath et al. | Feb 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 |
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 |
7257237 | Luck et al. | Aug 2007 | B1 |
7259747 | Bell | Aug 2007 | B2 |
7289645 | Yamamoto et al. | Oct 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 |
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 |
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 |
7574411 | Suontausta et al. | 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 |
7809167 | Bell | 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 |
7974443 | Kipman et al. | Jul 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 |
20020041327 | Hildreth et al. | Apr 2002 | A1 |
20030085887 | Hunt et al. | May 2003 | A1 |
20050031166 | Fujimura et al. | Feb 2005 | A1 |
20060098845 | Sotriropoulos et al. | May 2006 | A1 |
20060274947 | Fujimura et al. | Dec 2006 | A1 |
20080019589 | Yoon et al. | Jan 2008 | A1 |
20080026838 | Dunstan et al. | Jan 2008 | A1 |
20080037875 | Kim et al. | Feb 2008 | A1 |
20080107303 | Kim et al. | May 2008 | A1 |
20080201340 | Thonangi | Aug 2008 | A1 |
20080212836 | Fujimura et al. | Sep 2008 | A1 |
20080267447 | Kelusky et al. | Oct 2008 | A1 |
20090027337 | Hildreth | Jan 2009 | A1 |
20090110292 | Fujimura et al. | Apr 2009 | A1 |
20090228841 | Hildreth | Sep 2009 | A1 |
20090315740 | Hildreth et al. | Dec 2009 | A1 |
20100034457 | Berliner et al. | Feb 2010 | A1 |
20100094800 | Sharp | Apr 2010 | A1 |
20100194872 | Mathe et al. | Aug 2010 | A1 |
20100197390 | Craig et al. | Aug 2010 | A1 |
20100197392 | Geiss | Aug 2010 | A1 |
20100214322 | Lim et al. | Aug 2010 | A1 |
20100215257 | Dariush et al. | Aug 2010 | A1 |
20120092445 | McDowell et al. | Apr 2012 | A1 |
20120154373 | Finocchio et al. | Jun 2012 | A1 |
20120163723 | Balan et al. | Jun 2012 | A1 |
Number | Date | Country |
---|---|---|
100409261 | Aug 2008 | CN |
101246602 | Aug 2008 | CN |
101254344 | Sep 2008 | CN |
101320344 | Dec 2008 | CN |
0583061 | Feb 1994 | EP |
08044490 | Feb 1996 | JP |
9310708 | Jun 1993 | WO |
9717598 | May 1997 | WO |
9944698 | Sep 1999 | WO |
Entry |
---|
Podlozhnyuk, Victor. “Histogram Calculation in CUDA.” NVIDIA, 2007. |
Yang, Zhiyi, Yating Zhu, and Yong Pu. “Parallel image processing based on CUDA.” Computer Science and Software Engineering, 2008 International Conference on. vol. 3. IEEE, 2008. |
Coates, Adam, et al. “Scalable learning for object detection with GPU hardware.” Intelligent Robots and Systems, 2009. IROS 2009. IEEE/RSJ International Conference on. IEEE, (Oct. 10-15, 2009). |
Coates et al., “Scalable Learning for Object Detection with GPU Hardware”, Retrieved at << http://www.stanford.edu/˜acoates/papers/coates—iros2009.ps >>, 2009, pp. 7. |
Sharp, Toby, “Implementing Decision Trees and Forests on a GPU”, Retrieved at << http://research.microsoft.com/pubs/71445/ForestFire.pdf >>, 2008, pp. 595-608. |
Huisman, Johan “High-speed parallel processing on CUDA-enabled Graphics Processing Units”, Retrieved at << http://repository.tudelft.nl/assets/uuid:7ab16201-272c-4f18-899c-98a7fb527093/Thesis—-—Johan—Huisman.pdf >>, 2010, pp. 106. |
“Distributed Decision Tree Induction”, Retrieved at << http://www.slideshare.net/gregoryg/distributed-decision-tree-induction <<,Retrieved Date: Sep. 28, 2010, pp. 3. |
“High Performance Computing (HPC)—Supercomputing with NVIDIA Tesla”, Retrieved at << http://www.nvidia.com/object/tesla—computing—solutions.html >>, Retrieved Date: Sep. 28, 2010, pp. 2. |
“Distributed Decision Tree Training”, U.S. Appl. No. 12/7974,30, filed Jun. 9, 2010, pp. 36. |
Aggarwal et al., “Human Motion Analysis: A Review”, IEEE Nonrigid and Articulated Motion Workshop, Jul. 1997, University of Texas at Austin, Austin, TX. |
Athitsos, V. et al., “An Appearance-Based Framework for 3D Hand Shape Classification and Camera Viewpoint Estimation,” IEEE International Conference on Automatic Face and Gesture Recognition, May 2002, 6 pages. |
Azarbayejani et al., “Visually Controlled Graphics”, Jun. 1993, vol. 15, No. 6, IEEE Transactions on Pattern Analysis and Machine Intelligence. |
Breen et al., “Interactive Occlusion and Collusion of Real and Virtual Objects in Augmented Reality”, Technical Report ECRC-95-02, Feb. 1995, European Computer-Industry Research Center GmbH, Munich, Germany. |
Brogan et al., “Dynamically Simulated Characters in Virtual Environments”, Sep./Oct. 1998, pp. 2-13, vol. 18, Issue 5, IEEE Computer Graphics and Applications. |
Cohen, I. et al., “Inference of Human Postures by Classification of 3d Human Body Shape”, IEEE Workshop on Analysis and Modeling of Faces and Gestures, Mar. 2003, 8 pages. |
Fisher et al., “Virtual Environment Display System”, ACM Workshop on Interactive 3D Graphics, Oct. 1986, Chapel Hill, NC. |
Freeman et al., “Television Control by Hand Gestures”, Dec. 1994, Mitsubishi Electric Research Laboratories, TR94-24, Caimbridge, MA. |
Granieri et al., “Simulating Humans in VR”, The British Computer Society, Oct. 1994, Academic Press. |
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. |
He, “Generation of Human Body Models”, Apr. 2005, University of Auckland, New Zealand. |
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. |
“Human motion-capture for Xbox Kinect”, Retrieved at << http://research.microsft.com/en-us/projects/vrkinect/ >>, Retrieved Date: Apr. 15, 2011, 3 Pages. |
Isard et al., “Condensation—Conditional Density Propagation for Visual Tracking”, Aug. 1998, pp. 5-28, International Journal of Computer Vision 29(1), Netherlands. |
Jungling, et al.,“Feature Based Person Detection Beyond the Visible Spectrum”, IEEE Computer Society Conference on Computer Vision and Pattern Recognition Workshops, Jun. 20-25, 2009, pp. 30-37. |
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, Jun. 1996, pp. 196-202,The Robotics Institute, Carnegie Mellon University, Pittsburgh, PA. |
Khan, et al., “Real-time Human Motion Detection and Classification”, IEEE Proceedings Students Conference, Aug. 16-17, 2002, pp. 135-139. |
Kohler, “Special Topics of Gesture Recognition Applied in Intelligent Home Environments”, In Proceedings of the Gesture Workshop, Sep. 1997, pp. 285-296, Germany. |
Kohler, “Technical Details and Ergonomical Aspects of Gesture Recognition applied in Intelligent Home Environments”, 1997, Germany. |
Kohler, “Vision Based Remote Control in Intelligent Home Environments”, University of Erlangen-Nuremberg/Germany, 1996, pp. 147-154, Germany. |
Li, et al., “Real time Hand Gesture Recognition using a Range Camera”, Retrieved at << http://www.araa.asn.au/acra/acra2009/papers/pap128s1.pdf >>, Australasian Conference on Robotics and Automation (ACRA), Dec. 2-4, 2009, pp. 7. |
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. |
Miyagawa et al., “CCD-Based Range Finding Sensor”, Oct. 1997, pp. 1648-1652, vol. 44 No. 10, IEEE Transactions on Electron Devices. |
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. |
Plagemann, et al., “Real-time Identification and Localization of Body Parts from Depth Images”, Retrieved at <<http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=5509559 >>, IEEE International Conference on Robotics and Automation (ICRA), May 3-7, 2010, 6 Pages. |
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. |
Rosenhahn et al., “Automatic Human Model Generation”, Sep. 2005, pp. 41-48, University of Auckland (CITR), New Zealand. |
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. |
Sheridan et al., “Virtual Reality Check”, Technology Review, Oct. 1993, pp. 22-28, vol. 96, No. 7. |
“Simulation and Training”, 1994, Division Incorporated. |
Stevens, “Flights into Virtual Reality Treating Real World Disorders”, The Washington Post, Mar. 27, 1995, Science Psychology, 2 pages. |
Bolan, A. et al., “Classification of Posture States,” U.S. Appl. No. 12/979,897, filed Dec. 28, 2010, 28 pages. |
Bolan, A. et al., “Attribute State Classification,” U.S. Appl. No. 13/098,899, filed May 2, 2011, 38 pages. |
“Virtual High Anxiety”, Tech Update, Aug. 1995, pp. 22. |
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. |
Zhao, “Dressed Human Modeling, Detection, and Parts Localization”, Jul. 26, 2001, The Robotics Institute, Carnegie Mellon University, Pittsburgh, PA. |
State Intellectual Property Office of China, Office Action of Chinese Patent Application No. 201110443208.7, Nov. 21, 2013, 12 pages. |
State Intellectual Property Office of China, Office Action of Chinese Patent Application No. 201110447930.8, Jan. 24, 2014, 15 pages. |
Number | Date | Country | |
---|---|---|---|
20120154373 A1 | Jun 2012 | US |