US 6615158 B2 Abstract A system and method for analyzing a surface. The system includes a computer including a CPU and a memory medium operable to store programs executable by the CPU to perform the method. The method may include: 1) receiving data describing an n-dimensional surface defined in a bounded n-dimensional space, where the surface is embedded in an m-dimensional real space via embedding function x( ), and where m>n; 2) determining a diffeomorphism f of the n-dimensional space; 3) computing the inverse transform f
^{−1 }of the diffeomorphism f; 4) selecting points, e.g., a Low Discrepancy Sequence, in the n-dimensional space; 5) mapping the points onto the surface using x(f^{−1}), thereby generating mapped points on the surface; 6) sampling the surface using at least a subset of the mapped points to generate samples of the surface; and 7) analyzing the samples of the surface to determine characteristics of the surface.Claims(37) 1. A method for analyzing a surface, comprising:
receiving data describing an n-dimensional surface, wherein the surface is defined in a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a plurality of points in the n-dimensional space;
mapping the plurality of points onto the surface using x(f
^{−1}), thereby generating a mapped plurality of points on the surface; sampling the surface using at least a subset of the mapped plurality of points to generate samples of the surface; and
analyzing the samples of the surface to determine characteristics of the surface.
2. The method of
wherein the plurality of points comprises a Low Discrepancy Sequence;
wherein the mapped plurality of points comprises a mapped Low Discrepancy Sequence.
3. The method of
generating output comprising the mapped plurality of points in response to said mapping.
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
wherein the surface comprises a surface of an object;
wherein said analyzing comprises analyzing the samples of the surface to determine one or more characteristics of the object.
10. The method of
wherein the surface comprises an n-dimensional volume;
wherein said sampling comprises sampling the volume to generate samples of the volume;
wherein said analyzing comprises analyzing the samples of the volume to determine one or more characteristics of the volume.
11. The method of
wherein said analyzing comprises analyzing the samples of the volume to determine a motion path of a sensor in the volume.
12. The method of
wherein the surface comprises an image;
wherein said sampling comprises sampling the image to generate samples of the image;
wherein said analyzing comprises analyzing the samples of the image to determine characteristics of the image.
13. The method of
wherein the surface comprises a Riemannian manifold; and
wherein the received data comprises a Riemannian metric for the surface.
14. The method of
wherein the surface comprises a six-dimensional space describing degrees of freedom of a robotic arm; and
wherein the six dimensions correspond respectively to three positional degrees of freedom and three directional degrees of freedom.
15. The method of
wherein said robotic arm comprises a directional sensor;
wherein said sampling comprises measuring a vector field at one or more of the mapped plurality of points with the directional sensor.
16. The method of
wherein the surface comprises a multi-dimensional space describing degrees of freedom for first and second motion stages;
wherein the first and second motion stages couple respectively to first and second optical fibers, wherein a laser beam is directed through the first optical fiber, and wherein said sampling comprises measuring the laser beam intensity through the second optical fiber at one or more of the mapped plurality of points, the method further comprising:
moving one or both of the first and second motion stages until the measured laser beam intensity indicates that the optical fibers are substantially aligned.
17. A method for analyzing a surface, comprising:
receiving data describing a surface, wherein the surface is defined in a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the n-dimensional space;
mapping the Low Discrepancy Sequence onto the surface using x(f
^{−1}), thereby generating a mapped Low Discrepancy Sequence on the surface; and sampling the surface using at least a subset of the mapped Low Discrepancy Sequence to generate samples of the surface; and
analyzing the samples of the surface to determine characteristics of the surface.
18. The method of
wherein the surface comprises a surface of an object;
wherein said analyzing comprises analyzing the samples of the surface to determine one or more characteristics of the object.
19. A method for generating a Low Discrepancy Sequence on an abstract surface, comprising:
selecting an abstract surface S, wherein S is defined in a unit n-cube, wherein S is embedded in R
^{m }via an embedding function x( ), and wherein m>n; determining a diffeomorphism f of the unit n-cube;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the unit n-cube;
mapping the Low Discrepancy Sequence onto the embedded abstract surface S using x(f
^{−1}), thereby generating a Low Discrepancy Sequence on the abstract surface S; and generating output comprising the mapped Low Discrepancy Sequence.
20. The method of
sampling the abstract surface S using at least a subset of the mapped Low Discrepancy Sequence.
21. The method of
22. The method of
23. The method of
24. The method of
25. A system for analyzing a surface, comprising:
a sensor; and
a computer which is operable to couple to said sensor, said computer comprising:
a CPU;
a memory medium which is operable to store program instructions; and
an input for receiving data describing an n-dimensional surface, wherein the surface is defined in a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
wherein the CPU is operable to execute said program instructions to perform:
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a plurality of points in the n-dimensional space;
mapping the plurality of points onto the surface using x(f
^{−1}), thereby generating a mapped plurality of points on the surface; wherein said computer and said sensor are operable to perform:
sampling the surface using at least a subset of the mapped plurality of points to generate samples of the surface; and
wherein the CPU is further operable to execute said program instructions to perform:
analyzing the samples of the surface to determine characteristics of the surface.
26. The system of
wherein the plurality of points comprises a Low Discrepancy Sequence;
wherein the mapped plurality of points comprises a mapped Low Discrepancy Sequence.
27. The system of
generating output comprising the mapped plurality of points.
28. The system of
29. The system of
wherein the surface comprises a surface of an object;
wherein said analyzing comprises analyzing the samples of the surface to determine one or more characteristics of the object.
30. A system for analyzing a surface, comprising:
a sensor; and
a computer which is operable to couple to said sensor, said computer comprising:
a CPU;
a memory medium which is operable to store program instructions; and
an input for receiving data describing an n-dimensional surface, wherein the surface is defined in a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
wherein the CPU is operable to execute said program instructions to perform:
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the n-dimensional space; and
mapping the Low Discrepancy Sequence onto the surface using x(f
^{−1}), thereby generating a mapped Low Discrepancy Sequence on the surface; wherein said computer and said sensor are operable to perform:
sampling the surface using at least a subset of the mapped Low Discrepancy Sequence to generate samples of the surface; and
wherein the CPU is further operable to execute said program instructions to perform:
analyzing the samples of the surface to determine characteristics of the surface.
31. The system of
wherein the surface comprises a surface of an object;
32. A system for generating a Low Discrepancy Sequence on an abstract surface, comprising:
a computer which is operable to couple to said sensor, said computer comprising:
a CPU;
a memory medium which is operable to store program instructions; and
an input for receiving data describing an n-dimensional abstract surface, wherein the surface is defined in a unit n-cube, wherein the surface is embedded in R
^{m }via an embedding function x( ), and wherein m>n; wherein the CPU is operable to execute said program instructions to perform:
determining a diffeomorphism f of the unit n-cube;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the unit n-cube;
mapping the Low Discrepancy Sequence onto the embedded abstract surface using x(f
^{−1}), thereby generating a Low Discrepancy Sequence on the abstract surface; and generating output comprising the mapped Low Discrepancy Sequence.
33. A memory medium containing program instructions for analyzing a surface, wherein said program instructions are executable to perform:
receiving data describing an n-dimensional surface, wherein the surface is defined in a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a plurality of points in the n-dimensional space;
mapping the plurality of points onto the surface using x(f
^{−1}), thereby generating a mapped plurality of points on the surface; sampling the surface using at least a sub set of the mapped plurality of points to generate samples of the surface; and
analyzing the samples of the surface to determine characteristics of the surface.
34. The method of
wherein the plurality of points comprises a Low Discrepancy Sequence;
wherein the mapped plurality of points comprises a mapped Low Discrepancy Sequence.
35. A memory medium containing program instructions for analyzing a surface, wherein said program instructions are executable to perform:
receiving data describing a surface, wherein the surface is defined in (comprised in?) a bounded n-dimensional space, wherein the surface is embedded in an m-dimensional real space via an embedding function x( ), and wherein m>n;
determining a diffeomorphism f of the n-dimensional space;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the n-dimensional space;
mapping the Low Discrepancy Sequence onto the surface using x(f
^{−1}) thereby generating a mapped Low Discrepancy Sequence on the surface; and sampling the surface using at least a subset of the mapped Low Discrepancy Sequence to generate samples of the surface; and
analyzing the samples of the surface to determine characteristics of the surface.
36. The memory medium of
wherein the surface comprises a surface of an object;
37. A memory medium containing program instructions for generating a Low Discrepancy Sequence on an abstract surface, wherein said program instructions are executable to perform:
selecting an abstract surface S, wherein S is defined in a unit n-cube, wherein S is embedded in R
^{m }via an embedding function x( ), and wherein m>n; determining a diffeomorphism f of the unit n-cube;
computing the inverse transform f
^{−1 }of the determined diffeomorphism f; selecting a Low Discrepancy Sequence in the unit n-cube;
mapping the Low Discrepancy Sequence onto the embedded abstract surface S using x(f
^{−1}), thereby generating a Low Discrepancy Sequence on the abstract surface S; and generating output comprising the mapped Low Discrepancy Sequence.
Description The present invention relates to the field of measurement and data acquisition, and more particularly to the analysis of a surface of an object by generation or mapping of a point set on a Riemannian manifold or surface of the object and analyzing data values on the mapped point set to characterize the object. Many scientific and engineering tasks involve exploring, i.e., sampling or scanning, a region, such as an image, surface, or object, to acquire data characterizing the region. Examples of such tasks include parts inspection for automated manufacturing systems, alignment tasks for automated assembly systems, and detection, recognition, and location tasks in machine vision and motion control systems, among others. Another application relates to the determination of integrals of smooth functions defined on Riemannian geometries embedded in R In a typical sampling or scanning system a computer system is coupled to a sensor, such as a camera, which is operable to acquire optical, image, or other information from a target object or surface. The computer system may take any of various forms. The system may also include hardware and corresponding software which is operable to move one or both of the sensor and the target object to perform the scan or measurement. In robotics and motion planning an understanding of the underlying geometry of space is important. Various techniques have been developed to scan regions under various constraints or toward specific goals. In many cases the geometry is known in advance and a specific goal is desired, such as object recognition and/or characterization. In others the space in question may not be characterized, i.e., the nature of the space may be unknown. Exploration of such a space may involve goals such as determining the dimensionality and structure of a space with unknown underlying geometry, or finding critical points of a high-dimensional space. Typical applications of scanning spaces of known geometry include, but are not limited to: mine-countermeasure missions, continental shelf oceanographic mapping, contamination cleanup, floor scrubbing, crop plowing, non-destructive testing, and bridge inspections, among others. Many of these applications attempt efficient coverage of the space, and so involve determining a coverage plan for the scan region. Most coverage planners are still based on heuristics and the smoothness of the developed trajectories is rarely an issue. There are many coverage algorithms. In many cases the goal is to guide a robot or sensor to explore or to act within an environment. See, for example, J. Colgrave, A. Branch, “A Case Study of Autonomous Household Vacuum Cleaner”, AIAA/NASA CIRFFSS, 1994. See also M. Ollis, A. Stentz, “First Results in Vision-Based Crop Line Tracking”, IEEE International Conference on Robotics and Automation, 1996. One promising method in motion planning is based on Morse functions. These procedures look at the critical points of a Morse function to denote the topological changes in a given space. See, for example, Howie Choset, Ercan Acar, Alfred A. Rizzi, Jonathan Luntz, “Exact Cellular Decompositions in Terms of Critical Points of Morse Functions”. See also Ercan U. Acar, Howie Choset, “Critical Point Sensing in Unknown Environments”. However, Morse functions find their primary use with regard to the scanning of un-smooth surfaces, and so are not generally useful for many applications. Exploration tasks often relate to characterization of unknown spaces. One approach to efficient exploration of a surface or space is based upon Low Discrepancy Sequences (LDS), described below in some detail. However, current techniques generally involve generation of LDSs in simple Euclidean spaces, which may not be appropriate for more complex applications. Therefore, improved systems and methods are desired for generating a sampling point set, such as a Low Discrepancy Sequence, in a region or on a manifold or surface of an object. The present invention comprises various embodiments of a system, method, and memory medium for analyzing a surface, wherein the surface may be a surface of an object, a region, and/or an n-dimensional volume. The surface may also be a Riemannian manifold or an n-dimensional space describing degrees of freedom of an object or device, such as a motion device, e.g., a robotic arm. The method may involve generating a point set or sequence on the surface, acquiring data or taking measurements of the surface at these sample points, and analyzing the measured data to characterize the surface. The method may include generating a sequence, such as a Low Discrepancy Sequence, within a region or space in which the surface is defined. The sequence may be used for characterizing the surface, such as a high-dimensional space, or for motion planning. Embodiments of the invention include a method for generating a Low Discrepancy Sequence in a Riemannian manifold, e.g., on an n-dimensional surface. Specifically, an embodiment of the method is described in which a Low Discrepancy Sequence is generated on an n-dimensional space, for example, a unit square, then mapped to the manifold or surface. It is also contemplated that other sequences of points may be mapped in a similar manner, and that regions other than the unit n-square may be used. In one embodiment, the manifold may be a Riemannian manifold. In other words, the manifold may be characterized by a distance-like metric. In one embodiment, data may be received describing a surface which is defined in a bounded n-dimensional space, also referred to as a bounded n-space. In one embodiment, the bounded n-dimensional space may comprise a unit square. In another embodiment, the bounded n-dimensional space may comprise a unit cube. As mentioned above, in various other embodiments, the bounded n-dimensional space may comprise other geometries, including unit hyper-cubes, or unit n-cubes of dimensionalities greater than 3, as well as n-dimensional rectangles, spheres, or any other geometrical region. In one embodiment, the surface may further be embedded in an m-dimensional space, where m>n. In other words, the surface may be parameterized in terms of a higher dimensional space according to an embedding function x( ). The received data may include a Riemannian metric characterizing the surface or manifold. In one embodiment, the surface may comprise an image, and the received data may further comprise an intensity function describing the image, e.g., describing pixel information of the image. A diffeomorphism f of the bounded n-space may be determined. As is well known in the art, a diffeomorphism may be considered a mapping between two spaces which preserves differentiability of a mapped function. An inverse transform f In response to the selection of the plurality of points, the plurality of points may be mapped onto the surface via x(f The surface may be sampled or measured using at least a subset of the mapped plurality of points. In other words, measurements may be made at one or more of the mapped plurality of points, thereby generating one or more samples of the surface. Finally, the generated samples of the surface may be analyzed to determine one or more characteristics of the surface. For example, in one embodiment, the surface may comprise a surface of an object, and the analyzing may comprise analyzing the samples of the surface to determine one or more characteristics of the object. It should be noted that in some embodiments, the mapped plurality of points, e.g., the mapped Low Discrepancy Sequence, may simply be output for later use by the system or by other systems. In other words, the sampling and/or analyzing may be performed by other systems, or at a later time. In one embodiment, outputting the mapped points (Low Discrepancy Sequence) may comprise storing the Sequence for later use. In another embodiment, outputting the mapped Low Discrepancy Sequence may comprise displaying the sequence on a display device. Thus, by using the above-described method, a plurality of points, e.g., a Low Discrepancy Sequence, generated on a unit square (or other suitable geometry) may be mapped to a surface, such as an abstract surface or manifold. It should be noted that any point set generated on the unit square (or other suitable geometry) may be mapped in this way. This mapped plurality of points may operate to ideally represent or characterize the surface, wherein measurements taken at these mapped points indicate characteristics of the surface. In one embodiment, the above embodiment may be used to generate a scan path for a scanning application, such as a six degree of freedom alignment problem, for example. Other applications may include determination of scanning sequences for one or more robotic arms, where the scan space may describe degrees of freedom for the robotic arms, among others. For example, the scan space for the robotic arm may be a 6-dimensional space representing 3 positional degrees of freedom, and 3 directional or orientation degrees of freedom. Alternately, the degrees of freedom may relate to the degrees of freedom of joints or other articulated components of the arm. In one embodiment, the robotic arm may include a directional sensor, and the sampling may include measuring a vector field at one or more of the mapped plurality of points. One example of such an application relates to the location of an acoustic source via discrete sampling of sound strength and direction, such as by a directional microphone. One of the most straightforward applications for Low Discrepancy Sequences are calculations of integrals of smooth functions defined on Riemannian geometries embedded in R Another application field for Low Discrepancy Sequences is image processing, in which an intensity function of an image may be reinterpreted as a surface. In other words, the surface may comprise an image. Sampling of the image may comprise using or measuring pixel values at pixel locations corresponding to the mapped plurality of points. It should also be noted that in this embodiment, sampling may not necessarily involve measurement with a sensor, but rather may refer to calculation of an intensity value (or other pixel-related quantity) based on a function, e.g., an intensity function. The computed samples may then be analyzed to determine characteristics of the image. In one embodiment, the image may comprise information related to an object, where the analyzing may be performed to determine one or more characteristics of the object. A Riemannian metric for the surface based on the intensity function may be determined, as well as a diffeomorphism representing information contained in the intensity function. In real applications, the integrals may be replaced with sums of function values. More importantly, the inverse diffeomorphism in conjunction with appropriate sampling strategies in the unit square may allow an induced sampling of a given image content. Thus, an image may be considered an abstract Riemannian surface or manifold. It should be noted that although typical images are two-dimensional images, higher dimensional images are also contemplated. For example, complex multi-dimensional data sets may be considered images, and the methods described herein may be used to explore and characterize the data sets, or objects and features contained therein. Examples of 3-dimensional images include 3 d medical images, and 3 d seismic images, among others. It is also contemplated that data sets represented by even higher dimensional images (4 d and above) may be characterized by various embodiments of the present invention. In other words, any data set may be represented by an image of suitable dimensionality. The intensity values at selected points may describe the image content in an efficient manner and may be used to compress an image or to characterize its content. To a certain extent, the resulting description can be regarded as a generalized edge detector that is highly optimized for a specific image. Potential applications can be found in pattern matching where a given template should be characterized by a small amount of pixels, to speed up successive search operations. The use of low-discrepancy sets offers the advantages mentioned before. In one embodiment, data may be received describing an image which is defined in a bounded n-dimensional space, or n-space, and which may be embedded in an m-dimensional space, or m-space via an embedding function x( ), where m>n. In one embodiment, the bounded n-space may comprise a unit square (i.e., n=2). In other embodiments the bounded n-space may comprise a unit cube (n=3), a unit hyper-cube (n=4), or a unit n-cube where n>4. It is noted that the bounded n-space may not be limited to unit n-cubes, but may also comprise any other suitable geometry, including a unit n-sphere, rectangles of various dimensionalities, or any other geometry, as desired. It is also noted that the n-space needn't be of unit size, but may be of any size appropriate for the application or image under consideration. In one embodiment, the received data may include an intensity function, as mentioned above. For example, for a gray-scale image, the intensity function may describe the gray-scale pixel value at each point in the image. Similarly, for a color image, the intensity function may provide pixel data for each point in the image. A diffeomorphism (f,g) of the n-space may then be determined. As is well known in the art, a diffeomorphism may be considered a mapping between two spaces which preserves differentiability of a mapped function. An inverse transform (f After the selection of the plurality of points, the plurality of points may be mapped onto the surface via x(f Finally, the mapped plurality of points may be analyzed to determine one or more characteristics of the image. In one embodiment, the mapped plurality of points may be analyzed to detect edges in the image. In other embodiments, analyzing the mapped plurality of points may include performing pattern recognition, where features or objects comprised or represented in the image may be detected and/or characterized. Yet another application of the method relates to a fiber optic array alignment problem. Given an array of fibers where a second array of theses fibers must be aligned accurately. Typically, lasers are applied and the intensity of these beams may be measured to align the arrays. Said another way, the surface may comprise a multi-dimensional space describing degrees of freedom for a motion stage, or for first and/or second motion stages, where the first and second motion stages couple respectively to first and second optical fibers (or groups of optical fibers). A laser beam may be directed through the first optical fiber. Samples may be taken at a plurality of points in the search space, where the sampling includes measuring the laser beam intensity through the second optical fiber at one or more of the mapped plurality of points. One or both of the first and second motion stages may be moved until the measured laser beam intensity indicates that the optical fibers are substantially aligned. It should be noted that the above examples are meant to be illustrative, and are not intended to limit the domain of applicability of the method. A system may implement any of the above methods for generating a Low Discrepancy Sequence in a Riemannian Manifold or surface and for scanning or analyzing the surface. The system may comprise a computer system coupled to a sensor. An embodiment of the system may also include a motion control element, or actuator. The computer system may comprise a CPU and a memory medium, or programmable logic, which is operable to store a scanning or analysis program that implements one of the above methods. An embodiment of each of the above invention(s) may also be a software program or programs stored on a memory medium. A better understanding of the present invention can be obtained when the following detailed description of the preferred embodiment is considered in conjunction with the following drawings, in which: FIGS. 1A and 1B illustrate representative instrumentation and automation systems including various measurement options; FIG. 2 is a block diagram of the computer system of FIGS. 1A and 1B, suitable for implementing various embodiments of the invention. FIG. 3A illustrates a scanning system, according to one embodiment of the present invention; FIG. 3B illustrates a machine vision application of a scanning system, according to one embodiment; FIG. 3C illustrates a robotics application of a scanning system, according to one embodiment of the present invention; FIG. 3D illustrates a phased array control application of a scanning system, according to one embodiment of the present invention; FIG. 3E illustrates an optical fiber alignment system, according to one embodiment of the present invention; FIG. 4A illustrates a Halton Sequence and a random distribution of points; FIG. 4B illustrates a Low Discrepancy Sequence and an Induced Low Discrepancy Sequence, according to one embodiment; FIG. 4C illustrates Fourier Transforms of the Low Discrepancy Sequence and the Induced Low Discrepancy Sequence of FIG. 4B, according to one embodiment; FIG. 5A illustrates a well-distributed point set on the surface of a torus, according to one embodiment; FIG. 5B illustrates a well-distributed point set in a unit ball, according to one embodiment; FIG. 6 flowcharts a method for analyzing a surface using a mapped sequence of sample points, according to one embodiment; FIG. 7 illustrates edge detection in an image, according to one embodiment of the present invention; FIG. 8 flowcharts a method for analyzing an image using a mapped sequence of points, according to one embodiment; and FIG. 9 illustrates a simplified model of an alignment problem in fiber optics, according to one embodiment. While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and are herein described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the present invention as defined by the appended claims. Incorporate by Reference U.S. patent application Ser. No. 09/876,982 titled “System and Method for Generating a Low Discrepancy Curve on an Abstract Surface” which was filed on Jun. 8, 2001, and whose inventors are Lothar Wenzel, Ram Rajagopal, and Dinesh Nair, is hereby incorporated by reference in its entirety as though fully and completely set forth herein. FIGS. FIGS. 1A and 1B illustrate exemplary systems which may store or use programs for analyzing a surface, such as a surface of an object, as described herein. As shown, possible applications of the present invention include image processing/machine vision, instrumentation, industrial automation, process control, or other purposes. These programs may of course be stored in or used by other types of systems as desired. FIG. 1A illustrates an instrumentation control system The one or more instruments may include a GPIB instrument The GPIB instrument The GPIB card The VXI chassis or instrument A serial instrument (not shown) may also be coupled to the computer The instruments may be coupled through one or more sensors or transducers to the unit under test (UUT) or process FIG. 1B illustrates an exemplary industrial automation system The one or more devices may include a data acquisition board The DAQ card FIG. FIG. 2 is a block diagram of an exemplary computer system The computer system The computer may further include an Input/Output (I/O) interface (not shown) for communication with external systems, such as a display, keyboard, or mouse, a data acquisition device, or for communication with a network. In one embodiment, the computer system Referring again to FIGS. 1A, In addition, the memory medium may be located in a first computer in which the programs are executed, or may be located in a second different computer which connects to the first computer over a network, such as the Internet. In the latter instance, the second computer provides the program instructions to the first computer for execution. Also, the computer system In one embodiment, the software programs which implement the methods described herein are designed for data acquisition/generation, measurement, analysis and/or display, machine vision, simulation, or for controlling or modeling instrumentation or industrial automation hardware. Example applications where the method described herein may be used include inspection systems, industrial automation or motion control systems, measurement systems, image processing or machine vision systems, robotics, phased array systems and any other application where it is desirable to determine characteristics of an object or space by measuring (or sampling or scanning) a surface of the object or space. For more information on the generation of scan paths on abstract data sets see U.S. patent application Ser. No. 09/876,982 titled “System and Method for Generating a Low Discrepancy Curve on an Abstract Surface” which was filed on Jun. 8, 2001, which was incorporated by reference above. More specific applications wherein the method of the present invention may be used include robotics, and phased array control systems, as well as sampling or scanning related to image data, measurement data, acoustic data, seismic data, financial data, stock data, futures data, business data, scientific data, medical data, and biometric data, among others. However, it is noted that the present invention can be used for a plethora of applications and is not limited to the above applications. Thus, the method of the present invention may be implemented in any of various types of devices and any of various types of applications. FIGS. FIGS. 3A-E illustrate various exemplary applications where various embodiments of the present invention may be used. However, it is noted that the invention is not limited to these applications, but rather may be used in any of various applications. FIG. FIG. 3A illustrates an image processing system (or scanning system) according to one embodiment of the present invention. As FIG. 3A shows, computer system The sensor (camera In one embodiment, the computer system The computer system In this example, one sensor The camera The computer system FIG. In a machine vision or automated inspection application of the present invention, shown in FIG. 3B, a system similar to that shown in FIG. 3A may implement the present scanning methodology in software and/or hardware for quality control in a manufacturing process. As FIG. 3B shows, one or more cameras FIG. FIG. 3C illustrates an example application of the present invention in the field of robotics. As FIG. 2B shows, a computer system In one embodiment of the system shown in FIG. 3C, multiple robotic arms may be used in tandem. In this case, a cooperative sampling strategy may be required which coordinates the movement of each arm FIG. FIG. 3D illustrates an example application of the present invention in the area of phased array control. A phased array typically refers to a group of antennas in which the relative phases of the respective signals feeding the antennas are varied in such a way that the effective radiation pattern of the array is reinforced in a desired direction and suppressed in undesired directions. As FIG. 3D shows, computer system FIG. FIG. 3E illustrates an example machine motion application where the goal is a fast procedure for precise alignment of two optical fibers. In this example application, a laser source FIGS. Pseudo-random sequences have been used as a deterministic alternative to random sequences for use in Monte Carlo methods for solving different problems. Recently, it was discovered that there is a relationship between Low Discrepancy Sets and the efficient evaluation of higher-dimensional integrals. Theory suggests that for midsize dimensional problems, algorithms based on Low Discrepancy Sets may outperform all other existing methods by an order of magnitude in terms of the number of samples required to characterize the problem. Given a function ƒ(x,) the problem of calculating the integral in the most efficient manner is not a well posed problem. An approximate strategy may be based on the following procedure: (A) Construct an infinite sequence {x (B) During the n If a certain criterion is satisfied stop, else repeat step (B). The stopping criterion depends strongly on objectives such as accuracy or speed. This algorithm differs from standard methods such as the trapezoidal rule which is based on equally distributed points in [0, 1] in that there is no relationship between consecutive sets x Obviously, the quality of the trapezoidal rule is based on a highly homogeneous set of points. To quantify the homogeneity of a finite set of points, the definition of a discrepancy of a given set was introduced: Here, R runs over all rectangles [0, r] with 0≦r≦1, m(R) stands for the length r of the closed interval R, and p(R) is the ratio of the number of points of X in R and the number of all points of X. The definition given in equation (5) can be generalized to the case of d dimensions (d=2, 3, . . . ), where the term interval must be interpreted as a d dimensional rectangle. The lower the discrepancy the better or more homogeneous the distribution of the set. The discrepancy of an infinite sequence X={x There exists a set of points of given length that realizes the lowest discrepancy. It is well known in the art that the following inequality (6) holds true for all finite sequences X of length n in the d dimensional unit cube (the Roth bound, see Weisstein [1999] or Kocis and Whiten [1997]): B There are also infinite sequences X with for all for all sub-sequences consisting of the first n elements. The latter result gave rise to the definition of the Low Discrepancy (infinite) Sequences X. The inequality in equation (8) must be valid for all sub-sequences of the first n elements, where B Many of the well-studied low-discrepancy sequences in d-dimensional unit cubes (also referred to as unit n-cubes, where n is the dimensionality) can be constructed as combinations of 1-dimensional low-discrepancy sequences. The most popular low-discrepancy sequences are based on schemes introduced by Corput [1937], Halton [1960], Sobol [1967], and Niederreiter [1992]. The relationship between integrals, approximations, and an infinite sequence X={x where V(f) is the variation of f in the sense of Hardy and Krause. For more information regarding Low Discrepancy Sequences, please see the book “Random Number Generation and Quasi-Monte Carlo Methods”, by H. Niederreiter, CBMS-NSF Regional Conference Series in Applied Math., No. 63, SLAM, 1992, which gives a comprehensive introduction into the implementation of Low Discrepancy Sequences (Halton and Sobol'). The Halton method is described in detail below. All of the test results presented are based on Halton sequences. Halton sequences in 1-d start with the choice of a natural number greater than 1. Though not absolutely necessary, prime numbers p=2, 3, 5, . . . are typically chosen. If p is a given prime number and x (A) write n down in the p-ary system n=n (B) reverse the order of the digits and add the p-ary point 0.n (C) it is x The n FIG. 4A shows the first 1000 elements of a Halton sequence (left) in the unit square (a unit n-cube of dimension 2, i.e., n=2) for a valid choice of starting prime numbers, namely (2, 3). The graph on the right hand side is constructed with the aid of uniformly distributed random numbers. The differences are pronounced, as may be seen. Halton sequences in 1-D are Low Discrepancy Sets in the sense of equation (8). More precisely, for all n and for all Halton sequences X that are based on a prime number p: A similar result holds true for Halton sequences in d dimensional unit squares. In a 2-dimensional unit square for the (p,q) Halton sequence with prime numbers p and q the discrepancy is FIGS. The question arises whether an area-preserving map up to a constant factor from [0,1] where (f,g) is a diffeomorphism of [0,1] Theorem 1: Let Ψ(u,v) be a nonnegative function on [0,1] Furthermore, let the functions f and g be extendable to continuously differentiable mappings defined on [0,1] It is noted that the set of points L refers to the few points which are not well-behaved, and so are excluded from consideration. Proof: The denominators in (9) are positive. The extensions of f and g map [0,1] g(u,v)=g(u′,v′) implies v=v′ and from f(u,v)=f(u′v) it follows that u=u′. q.e.d. Theorem 1 allows the construction of well-distributed sets D of points on R The algorithm is straightforward: Algorithm I: (I.1) Given an abstract surface S defined on [0,1] (I.2) According to Theorem 1 a diffeomorphism (f(u,v),g(u,v)) of [0,1] (I.3) Compute the inverse transform (f (I.4) Let D be a well-distributed set in [0,1] Because of (8) the latter transform preserves areas (up to a constant factor). In particular, (I.1)-(I.4) provides a method to preserve low-discrepancy properties. The algorithm (I.1)-(I.4) also produces a new abstract surface:
where the resulting area element dA One of the simplest examples is the abstract surface defined by
There is an embedding in R FIG. 4B compares a low-discrepancy set derived from such a sequence in [0,1] A more sophisticated example is a part of a sphere given as an abstract surface by ds An R FIG. Another example deals with the surface of a torus. The R
Algorithm (I.1)-(I.4) delivers After computing the inverse transform, homogeneous point sets lying on the surface of a torus can be generated. FIG. 5 shows such a distribution and projections onto different planes. As FIG. 5 clearly shows, the induced point set is distributed homogeneously over the surface. Higher Dimensional Riemannian Geometries In 3- or n-dimensional Riemannian geometries the term area preserving may be replaced with volume preserving or content preserving. Volume or content preserving mappings (up to a constant factor) are characterized by
It is natural to generalize Theorem 1 in the following manner. Theorem 2: Let Ψ(u Furthermore, let the functions f Proof: The specific structure of these functions simplifies the determinant of the Jacobian of f to exactly one product The rest is similar to proof of Theorem 1. q.e.d. Algorithm I may be generalized to n dimensions as follows: Algorithm II: (II.1) Given an abstract surface S defined on [0,1] (II.2) According to Theorem 2 a diffeomorphism f(u (II.3) Compute the inverse transform f (II.4) Let D be a well-distributed set in [0,1] FIG. FIG. 5B illustrates an induced point set in a unit ball embedded in an n-dimensional (n=3) Euclidean space. Given the unit ball in n-dimensional Euclidean space in standard parameterization
it turns out that
Applying Theorem 2 leads to functions The functions f It is worthwhile to note that the alternative approach of deriving a well-distributed set based on the surrounding unit n-cube suffers from serious limitations. The content or volume of such an n cube is 1, the content of an n-dimensional unit ball is which is on the order of In other words, the probability to hit the n ball is extremely small when n is beyond 10. Said another way, the volume in the unit cube which is outside the unit ball is in the corners of the cube. The higher the dimensionality of the unit n-cube, the more corners there are, thus the smaller the ratio of the ball volume to the n-cube volume. FIG. FIG. 6 is a flowchart one embodiment of a method for generating a sequence, such as a Low Discrepancy Sequence, on a surface or manifold, e.g., on an abstract surface. Specifically, an embodiment of the method is described in which a sequence or point set, e.g., a Low Discrepancy Sequence, is generated on an n-dimensional space, for example, a unit square, then mapped to the manifold, although it is also contemplated that other sequences of points may be mapped in a similar manner, and that regions other than the unit n-square may be used. In one embodiment, the manifold may be a Riemannian manifold. In other words, the manifold may be characterized by a distance-like metric. It should be noted that in various embodiments, one or more of the steps may be performed in a different order than shown, or may be omitted as desired. Furthermore, additional steps may be performed as desired. As FIG. 6 shows, in In one embodiment, the bounded n-dimensional space may comprise a unit square. In another embodiment, the bounded n-dimensional space may comprise a unit cube. As mentioned above, in various other embodiments, the bounded n-dimensional space may comprise other geometries, including unit hyper-cubes, or unit n-cubes of dimensionalities greater than 3, as well as n-dimensional rectangles, spheres, or any other geometrical region. In one embodiment, the surface may further be embedded in an m-dimensional space, where m>n. In other words, the surface may be parameterized in terms of a higher dimensional space according to an embedding function x( ). In one embodiment, the received data may include a Riemannian metric characterizing the surface or manifold. In another embodiment, the surface may comprise an image, and the received data may comprise an intensity function describing the image, e.g., describing pixel information of the image. In In Then, as indicated in In In Finally, in In many applications the surface and/or object may be an abstract surface or object, such as a data set describing a phenomenon or relationship. For example, in a seismic signal processing application, acoustic signal strengths on the surface or interior of a volume may be analyzed to determine the presence of geologic structures indicative of oil or mineral deposits. In a financial application, company stock metrics such as stock price, price/earnings ratios, earnings, and volatility, among others, may be analyzed to determine characteristic patterns or formations indicating buy or sell conditions. Similarly, futures data such as pricing, term information, and volume, among others, may be analyzed to determine expected values for given contracts. In a medical application, for example, 2- or 3-dimensional image data for x-ray charts, positron emission tomography, computer-aided tomography, ultra-sound, or other medical images and data sets may be sampled and analyzed for diagnostic purposes. In other words, specific patterns or features may be detected and characterized to diagnose a medical condition. For example, EKG data may be analyzed to characterize the health of a patient's heart, e.g., to determine the likelihood of a heart attack. Similarly, EEG data may be analyzed to determine brain function (or malfunction) indicating brain pathologies, such as the presence of a tumor. It is also noted that non-pathological aspects of the body may be researched using various embodiments of the present invention, such as blood flow, neurological activity, or other physiological metrics. In other words, the present invention also lends itself to research, as opposed to being restricted in use for diagnostics. In a more abstract medical application, multi-dimensional diagnostic metrics in an abstract space may be analyzed, and pattern matching algorithms used to diagnose complex multi-system health conditions or functionality in a patient. In a robotics application degrees of freedom information regarding the operation of one or more robotic arms may be analyzed to determine efficient motion paths through spaces with complex constraints, such as robotically aided micro-surgery or tele-surgery, where a surgeon (or software program) at one location manipulates surgical robotic arms to perform surgery on a patient at a second location. In another machine vision application, an autonomous robot may map terrain information into an abstract space to simplify obstacle avoidance methods. In other words, certain algorithms for characterizing and/or avoiding obstacles may be substantially simplified by mapping the terrain data prior to analysis. This may result in real time performance of algorithms not feasible otherwise. It should be noted that in some embodiments, the mapped plurality of points, e.g., the mapped Low Discrepancy Sequence, may simply be output for later use by the system or by other systems. In other words, the sampling and/or analyzing of Thus, by using the above-described method, a plurality of points, e.g., a Low Discrepancy Sequence, generated on a unit square (or other suitable geometry) may be mapped to a surface, such as an abstract surface or manifold. It should be noted that any point set generated on the unit square (or other suitable geometry) may be mapped in this way. In one embodiment, the surface may comprise an image, and the sampling may comprise sampling the image to generate samples of the image. It should be noted that in this embodiment, sampling may not necessarily involve measurement with a sensor, but rather, may refer to calculation of an intensity value (or other pixel-related quantity) based on a function, e.g., an intensity function. In another embodiment, the sampling may involve reading pixel data from an image file. The computed samples may then be analyzed to determine characteristics of the image. In one embodiment, the image may comprise information related to an object, where the analyzing may be performed to determine one or more characteristics of the object. In one embodiment, the above method may be used to generate a scan path for a scanning application, such as a six degree of freedom alignment problem, for example, as described below in the section titled Example Applications. Other applications may include determination of scanning sequences for one or more robotic arms, where the scan space may describe degrees of freedom for the robotic arms, among others. For example, the scan space for the robotic arm may be a 6-dimensional space representing 3 positional degrees of freedom, and 3 directional or orientation degrees of freedom. Alternately, the degrees of freedom may relate to the degrees of freedom of joints or other articulated components of the arm. In one embodiment, the robotic arm may include a directional sensor, and the sampling may include measuring a vector field at one or more of the mapped plurality of points. One example of such an application relates to the location of an acoustic source via discrete sampling of sound strength and direction, such as by a directional microphone. It should be noted that such examples are meant to be illustrative, and are not intended to limit the domain of applicability of the method. Example Applications: Exploration of an Unknown Higher Dimensional Space In some cases the geometry of an underlying space may be unknown. An example is given by a car seat which has six degrees of freedom. In this example, some combinations of movement are valid and others are invalid. The goal is a description of this space in terms of valid combinations (6 coordinates each). Critical points in this space may be determined by efficient exploration of the space through the use of a Low Discrepancy Sequence. Direction Dependent Sensing in 3 d A typical scanning problem arises when electromagnetic, acoustic, or other fields must be explored where the sensor works in a direction-selective manner and can be moved freely, e.g. the point of maximal strength of an acoustic field in a given room must be determined and the microphone must be directed to take a measurement. From a purely scanning standpoint, a 6-dimensional space must be scanned efficiently. Low-discrepancy Sequences in 6 d will detect this point faster on average than other methods. Moreover, standard techniques such as grid-like scanning methods are almost unrealizable because of the unbalanced structure of these sequences. Integration As mentioned above, one of the most straightforward applications for Low Discrepancy Sequences are calculations of integrals of smooth functions defined on Riemannian geometries embedded in R Image Processing Another application field for Low Discrepancy Sequences is image processing. Assume the intensity of an image is described by I(u,v) where (u,v) fills the unit square. Furthermore, let I(u,v) be sufficiently smooth in u and v. Such an image can be reinterpreted as a surface (u,v,I(u,v)) and Theorem 1 can be applied. The Riemannian metric belonging to I(u,v) is The resulting diffeomorphism (f(u,v),g(u,v)) represents information contained in I(u,v). In applications, the integrals are replaced with sums of function values. More importantly, the inverse diffeomorphism in conjunction with appropriate sampling strategies in [0,1] It should be noted that, although the image described above is a two-dimensional image, higher dimensional images are also contemplated. For example, complex multi-dimensional data sets may be considered images, and the methods described herein may be used to explore and characterize the data sets, or objects and features contained therein. Algorithm III: (III.1) Compute ( (III.2) Determine the inverse diffeomorphism according to Theorem 1. (III.3) Choose a Low Discrepancy Sequence in [0,1] (III.4) Compute the image sequence of this Low Discrepancy set under the diffeomorphism mentioned in (III.2). The intensity values of I at these points (the mapped Low Discrepancy Sequence) describe the image content in an efficient manner and can be used to compress an image or to characterize its content. To a certain extent, the resulting description can be regarded as a generalized edge detector that may be highly optimized for a specific image. Potential applications can be found in pattern matching where a given template should be characterized by a small amount of pixels, to speed up successive search operations. The use of low-discrepancy sets offers the advantages mentioned before. FIG. 7 demonstrates the effect of Algorithm III on a given image. The small rectangles represent the sampling points computed by Algorithm III. As FIG. 7 shows, the algorithm identifies the edges and other significant points. Other examples of image processing tasks suitable for various embodiments of the present invention include pattern or object recognition and/or detection, and object characterization, among others. FIG. FIG. 8 flowcharts one embodiment of a method for processing and analyzing an image. It should be noted that as used herein, the term “image” may refer not only to a 2-dimensional image, but to a higher dimensional image, e.g., images of 3-dimensions or more, as well. Examples of 3-dimensional images include 3 d medical images, and 3 d seismic images, among others. It is also contemplated that data sets represented by even higher dimensional images (4 d and above) may be characterized by various embodiments of the present invention. In other words, substantially any data set may be represented by an image of suitable dimensionality, where sampling may refer to extracting or reading data from the data set. As FIG. 8 shows, in In one embodiment, the received data may include an intensity function, as mentioned above. For example, for a gray-scale image, the intensity function may describe the gray-scale pixel value at each point in the image. Similarly, for a color image, the intensity function may provide pixel data for each point in the image. It is noted that various other quantities may also be represented by the intensity function. In In Then, as indicated in In Finally, in As noted above, in The embedding strategies in image processing as described herein enable the use of well-developed differential geometrical methods to solve existing and/or new problems. Differential geometry deals with smooth (differentiable) objects in spaces of dimension 1, 2, 3, . . . Some of these spaces are very familiar, e.g. n-dimensional Euclidean spaces, and some of them are abstract mathematical constructions. However, even these abstract mathematical spaces allow embeddings in Euclidean spaces of even higher dimensions. In general, an embedding in R According to various embodiments of the invention, the field of image processing provides for countless natural and mathematically oriented embeddings. The most natural is the interpretation of a gray-scale image as a surface in 3D. This surface may be referred to as a Monge patch. This interpretation is based on 2 independent variables x and y (location) and one dependent variable I(x,y)—intensity. The structure: (x, y, I(x,y)) may form a surface in three-dimensional Euclidean space. Another example is an RGB image. The structure is (x, y, R(x,y), G(x,y), B(x,y)) which is a surface in 5-dimensional Euclidean space. This results in a 5D embedding of a color image. These two examples are relatively straightforward. The following is an exemplary collection of more complex embeddings. (1) Given a gray-level image I(x,y), construct an artificial abstract surface based on the Riemannian metric:
This abstract surface may be used to generate embeddings in higher dimensional spaces (it is very difficult to depict these abstract surfaces). In doing so, new classes of algorithms can be derived. (2) The color space of all colors can be interpreted as a specific Riemannian space. Based on this an embedding can be constructed. (3) Same as (1) but R, G, and B values of a color image generate an unusual embedding
(4) Instead of using intensity values, one can also start with curvature or other features. This results in a natural embedding, where the 2D image is considered to be embedded in a higher dimensional space (3D or higher), wherein the higher dimensional space includes one or more additional dimensions (additional to x and y) based on or derived from the curvature or other features. Various other types of embeddings may be used according to various embodiments of the invention. Testing and Exploration A typical scenario in nondestructive testing or during search routines is based on well-chosen locations where measurements are taken. Usually, the search space is large and a specific point operation is computationally or otherwise expensive. Efficient sampling and/or scanning strategies are necessary for reasonable performance. It is assumed here that an efficient search strategy for an n-dimensional cube is available. Such a strategy could be based on low-discrepancy sets, homogenous grids, or other approaches. With the aid of Theorem 2 an induced strategy can be derived. FIG. FIG. 9 illustrates a simplified fiber optic array alignment problem, given an array of fibers where a second array of theses fibers must be aligned accurately. Typically, lasers are applied and the intensity of these beams may be measured to align the arrays. Said another way, the surface may comprise a multi-dimensional space describing degrees of freedom for first and second motion stages, where the first and second motion stages couple respectively to first and second optical fibers (or groups of optical fibers). A laser beam may be directed through the first optical fiber. Samples may be taken at a plurality of points in the search space, where the sampling includes measuring the laser beam intensity through the second optical fiber at one or more of the mapped plurality of points. One or both of the first and second motion stages may be moved until the measured laser beam intensity indicates that the optical fibers are substantially aligned. In one embodiment, if the first array is regarded as fixed with unknown position and orientation, the second array may be moved to establish an alignment. A simple model of this scenario, shown in FIG. 9, consists of 3 position degrees of freedom (x, y, and z) in combination with 3 orientation degrees of freedom (pitch α, roll β, and yaw angle γ). This results in a 6-dimensional search space (surface) where further constraints add complexity to this space. For example,
where P(osition) and O(rientation) are known parameters and α In one embodiment, the degrees of freedom of both motion stages may be represented by the search space or surface. In this embodiment, the space may be 12-dimensional, in that each motion stage has 3 positional degrees of freedom and 3 orientation degrees of freedom. Networks Tenenbaum et al. [2000], Roweis and Saul [2000] report methods of constructing manifolds representing large data sets. The algorithms describe data globally where local properties are used. The procedures are based on nearest neighbors. Included is the determination of the dimensionality of the data under consideration. Given a large set of discrete points in a manifold, a well-distributed subset of points of this graph may be determined. Such a set should treat all parts of the point set equally well. The following algorithm can be applied. Algorithm IV: (IV.1) Apply Theorem 2 to generate a low-discrepancy set in this manifold. (IV.2) Determine nodes and edges of the graph that minimize the distance to this set of the manifold. To this end, appropriate thresholds must be given. If the number of points of the subset under construction is unknown in advance the algorithm can stop whenever a certain goal is achieved, e.g. any point of the underlying point set is in a neighborhood of a point constructed so far. Probability Distributions Sometimes, one is interested in a well-chosen point set where an underlying probability distribution is known. For example, find a point distribution in [0,1]
Using Theorem 1, appropriately chosen sets of points can be derived from equally distributed sequences in [0,1] Memory and Carrier Medium The computer system The term “memory medium” is intended to include an installation medium, e.g., a CD-ROM, floppy disks, or tape device; a computer system memory or random access memory (RAM) such as DRAM, SRAM, EDO RAM, RRAM, etc.; or a non-volatile memory such as a magnetic media, e.g., a hard drive, or optical storage. The memory medium may comprise other types of memory as well, or combinations thereof. In addition, the memory medium may be located in a first computer in which the software program is stored or executed, or may be located in a second different computer which connects to the first computer over a network, such as the Internet. In the latter instance, the second computer provides the program instructions to the first computer for execution. Also, the computer system Various embodiments further include receiving or storing instructions and/or data implemented in accordance with the foregoing description upon a carrier medium. Suitable carrier media include a memory medium as described above, as well as signals such as electrical, electromagnetic, or digital signals, conveyed via a communication medium such as networks and/or a wireless link. However, it is noted that the present invention can be used for a plethora of applications and is not limited to the applications shown herein. In other words, the applications described herein are exemplary only, and the methods described herein may be used for any of various purposes and may be stored in and execute on any of various types of systems to perform any of various applications. Although the embodiments above have been described in considerable detail, numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |