The present disclosure relates to measurement of surface geometry, and more particularly relates to measuring the shape of an object using illumination.
Objects fabricated from a highly glossy or specular material have reflection characteristics that differ significantly from those fabricated from a diffuse material. For example, where for a diffuse material, light from a directional light source such as a projector is reflected in virtually all directions, for a highly glossy material, such light is reflected in primarily only one direction or at most only a few directions. As a consequence, conventional 3D scanning methods such as structured light and photometric stereo typically do not perform well when applied to objects fabricated from a highly glossy material.
A number of alternative techniques for measuring the surface geometry of highly glossy objects have been considered. One example technique is continuous area illumination, where the light source used to illuminate the object is composed of a high density of light-producing or light-modulating pixels and each pixel is dynamically programmable in its intensity and/or color. One example of a continuous area light source is a common color display. Because of the practically continuous area light source, every surface point of the object is illuminated in a continuous range of angles, and a camera set at a fixed predetermined position can observe a specular reflection. For measurement efficiency, techniques of continuous area illumination typically display a sequence of patterns on the display, instead of displaying one pixel at a time. A common choice of such patterns is based on the Gray code.
Techniques of continuous area illumination typically assume either that the continuous area light source is far away from the object (e.g. far field illumination) and/or that the object being measured is nearly flat. This is because continuous area illumination typically involves determining the location of a pixel on the light source that is causing a specular reflection at a point on the object. This information, however, cannot be used to uniquely determine the direction of the incident light ray, and in turn the depth at that point of the object, without making an additional assumption such as a distant light source or a nearly flat object. This phenomenon is sometime referred to as the “depth-normal ambiguity”.
To resolve the depth-normal ambiguity without assuming one of either a distant light source or a nearly flat surface, it has been considered to perform continuous area illumination using multiple layers of displays (e.g. multiple LCD displays). See, for example, U.S. application Ser. No. 14/489,008, filed Sep. 17, 2014 and assigned to the Applicant herein, entitled “Depth Value Measurement Using Illumination By Pixels” by Siu-Kei Tin and Mandi Nezamabadi (herein after “Tin et al.”), which is incorporated herein by reference as if set forth herein in full.
One difficulty with the foregoing approach is that the number of image captures required is directly proportional to the number of layers of displays used. For example, a method that uses two LCD displays in order to resolve the depth-normal ambiguity without any additional assumptions would ordinarily require twice the number of image captures.
The foregoing difficulty is addressed by displaying patterns on the multiple layers of displays that encode only the direction of incident light rays, and by arranging the multiple layers of displays and the object being measured in such a way that only the light rays that strike the object are encoded. This allows for the patterns to be displayed on each layer of the display simultaneously and in synchronization with each other while still encoding sufficient information to determine only the direction of the incident light rays. This allows for a reduction of the number of required image captures when compared to previous methods which typically require patterns to be displayed on each layer separately in order to encode both direction and position of the incident light rays.
Thus, in an example embodiment described herein, measuring a surface geometry of an object involves capturing one or more images of the object illuminated by a light field produced by a luminaire having multiple pixel-layers with overlapping fields of illumination. Each pixel-layer simultaneously and in synchronization with each other displays multiple coded patterns such that combinations of the multiple coded patterns uniquely identify directions of light rays originating from the multiple pixel-layers. A unique incident light ray direction for one or more pixels of the captured one or more images is determined by decoding the combinations of the multiple coded patterns. The surface geometry of the object is recovered using the determined unique incident light ray direction for each of the one or more pixels of the one or more captured images.
Because of this arrangement, it is ordinarily possible to measure the surface geometry of a highly specular object without assuming a distant light source or a nearly flat object, and to do so using a reduced number of image captures.
In examples of this arrangement, recovering the surface geometry of the object may involve determining a surface normal vector field of the object based on the determined unique incident light ray direction for each of the one or more pixels of the one or more captured images.
In other examples, recovering the surface geometry of the object may involve determining points on the surface of the object by triangulation of the unique incident light ray direction and a viewing direction from a camera for each of the one or more pixels of the one or more captured images.
The combinations of the multiple coded patterns displayed by the multiple pixel-layers can encode differences in pixel location coordinates of pixels located on two of the multiple pixel-layers. In some examples, each pixel of a pixel-layer is associated with an admissible cone that determines a maximum difference in pixel location coordinates that can be encoded.
The pixels in the multiple pixel-layers may have the same dot pitch and aspect ratio. At least two of the multiple pixel-layers may largely be in parallel to each other and separated by a perpendicular distance. Additionally, the multiple pixel-layers may be positioned such that they are laterally shifted relative to each other.
The multiple coded patterns may be based on a binary Gray code. Moreover, a minimum-run-length (MRL) of the binary Gray code may determine a maximum difference in pixel location coordinates of pixels located on two of the multiple pixel-layers that can be encoded. In one example, the minimum-run-length of the binary Gray code is 8.
In another example embodiment described herein, an apparatus for measuring a surface geometry of an object includes a plurality of luminaires. Each luminaire includes multiple pixel-layers with overlapping fields of illumination and the luminaires are positioned to surround the object. The apparatus further includes a pattern displaying module constructed to cause each pixel-layer of each luminaire to simultaneously and in synchronization with each other display multiple coded patterns. Combinations of the multiple coded patterns may uniquely identify directions of light rays originating from the multiple pixel-layers of each luminaire and may uniquely identify each luminaire. The apparatus further includes an image capture device constructed to capture one or more images of the object. A direction determining module is constructed to determine, for each pixel of the captured one or more images, a unique light ray direction by decoding the combinations of the multiple coded patterns. A depth recovering module is constructed to recover the surface geometry of the object using the determined unique incident light ray direction for each pixel of the one or more captured images.
In some examples, the direction determining module determines the unique light ray direction in steps that include determining an identity of one of the luminaires that the light ray originates from, by decoding the combinations of the multiple coded patterns.
In some examples of the apparatus, pixels in the multiple pixel-layers of a luminaire of the plurality of luminaires may have the same dot pitch and aspect ratio.
Some embodiments may be implemented as a method or methods according to any of the disclosure herein. Some embodiments may be implemented as an apparatus or apparatuses according to any of the disclosure herein. Representative embodiments of such apparatus may be implemented as one or more processors constructed to execute stored process steps together with memory, which stores the process steps described herein for execution by the processor(s). Other representative embodiments of such apparatus may be implemented as units constructed to execute processes described herein, with such units, for example, being implemented by computer hardware in combination with software which when executed by the computer hardware causes the computer hardware to execute such processes. Some further embodiments may be implemented as non-transitory computer-readable storage media, which retrievably store computer-executable process steps which when executed by a computer cause the computer to execute such process steps.
This brief summary has been provided so that the nature of this disclosure may be understood quickly. A more complete understanding can be obtained by reference to the following detailed description and to the attached drawings.
In particular, as shown in
Meanwhile, specular reflections caused by the illumination are captured by image capture device 102. For purposes of clarity,
As shown in
A backlight may be used in some embodiments to provide the light source. On the other hand, in some embodiments a backlight may be optional.
Luminaire 101 may be manufactured so that distances between the pixel-layers can be predetermined with high accuracy and precisions. Alternatively, the pixel-layers can be geometrically calibrated in an offline calibration process. Either way, since there is ordinarily no movement of the stack as a whole or relative movement of the layers within the stack during the online measurement process, it can be assumed that these distances and other geometric parameters are known without an online calibration step.
Each pixel-layer, or at least one pixel-layer, may be an array of spatial light modulator (SLM) pixels and not self-luminous. Examples of SLM pixels include liquid crystal display (LCD) pixels and digital micromirror device (DMD) pixels. In alternative examples, each pixel-layer may be an array of light emitting diodes (LEDs) and self-luminous.
According to the disclosure, a light pattern results from one or more coded patterns transmitted to the pixel-layers. A pixel-layer might include a 2-dimensional array of pixels, in which case there is a pixel resolution associated with each dimension, e.g., 1920×1080. A pixel ordinarily does not need to be self-luminous, i.e., it does not need to emit light by itself. For example, in a typical LCD display, there is a backlight source and the LCD panel modulates the backlight based on the image signal. In addition, in a color LCD display, each pixel consists of different color sub-pixels and is capable of modulating light intensity in different wavelength ranges and of displaying colors.
Although image capture device 102 is depicted as a camera, it should be understood that various other image capture devices can be used.
According to the arrangement shown in
As shown in
RAM 216 interfaces with computer bus 215 so as to provide information stored in RAM 216 to CPU 210 during execution of the instructions in software programs, such as an operating system, application programs, image processing modules, and device drivers. More specifically, CPU 210 first loads computer-executable process steps from non-volatile memory 256, or another storage device into a region of RAM 216. CPU 210 can then execute the stored process steps from RAM 216 in order to execute the loaded computer-executable process steps. Data can also be stored in RAM 116 so that the data can be accessed by CPU 210 during the execution of the computer-executable software programs, to the extent that such software programs have a need to access and/or modify the data.
As also shown in
Non-volatile memory 256 also stores a surface measurement module 240. The surface measurement module 240 comprises computer-executable process steps for determining the surface geometry of an object based on illumination based direction coding.
As shown in
These modules will be discussed in more detail below with respect to
The computer-executable process steps for these modules may be configured as part of operating system 218, as part of an output device driver in output device drivers 221, or as a stand-alone application program. These modules may also be configured as a plug-in or dynamic link library (DLL) to the operating system, device driver or application program. It can be appreciated that the present disclosure is not limited to these embodiments and that the disclosed modules may be used in other environments.
As shown in
Normal vector field determining module 245 determines a surface normal vector field of the object based on the unique light ray directions determined by direction determining module 244. Depth recovering module 246 determines points on the surface of the object from the determined surface normal vector field or by triangulation of the unique incident light ray direction and a viewing direction for each of the one or more pixels of the captured images. The determined unique incident light ray directions, surface normal vector field, and determined points on the surface of the object may all be stored with the image data, for example, in non-volatile memory 256.
Returning to
First, the multiple pixel-layers of the luminaire 101 produce a light field that illuminates the object 103. In particular, for the case of N=2 layers, the light field consists of light rays joining a pixel on one pixel-layer to another pixel on another pixel-layer. layer. If both pixel-layers are 2-dimensional arrays of pixels with horizontal pixel resolution rx and vertical pixel resolution ry, for example rx=1920, ry=1080 for display panels of resolution 1920×1080, the size of this light field is (rxry)2 , so that a binary encoding of the full light field would require 2(log2 rx+log2 ry) bits.
However, not all of the light rays produced by the multiple pixel-layers are needed. In particular, it is possible to arrange the pixel-layers and the object 103 in such a way that some of the light rays would never hit the object. Such an arrangement would allow for encoding of only the useful light rays that hit the object, so that the number of bits required can be reduced. As explained more fully below, this is accomplished by introducing the concept of an “admissible cone” for each pixel.
The second key insight is that the encoding of each light ray generally includes both its position and direction. However, in applications involving the reconstruction of the normal vector field of the object, it is only necessary to determine the direction of the light rays. Further saving can therefore be achieved by encoding only the direction of the light rays in the admissible cone.
In
The other boundary of the admissible cone is controlled by a parameter m, which determines the number of light rays in the admissible cone. As further shown in
Γ(q1)=Γ00(q1)={{right arrow over (q1q2)}|q1x−m≦q2x≦q1x,q1y−m≦q2y≦q1y} (Equation 1)
In Equation 1, the subscripts x and y signify taking the position index in the x and y directions respectively. Note that this is a “one-sided” cone. Also, within the cone, pixel location coordinates of q1 and q2 are bounded by m, which is a maximum difference in pixel location coordinates that can be encoded. Three other alternative choices of the admissible cone are:
In Equations 1 and 2-A to 2-C, the choice of m is dependent on available coding schemes, as explained more fully below. The choice of m is typically a small number, e.g., m=8.
By running through all the pixels q1 on the back pixel-layer, the admissible region for the whole luminaire can be obtained and is defined as the region in space where every individual admissible cone can affect:
The admissible region is a cone itself with its vertex at (X, Y, Z) given by:
When an object is within the admissible region of the luminaire, it is subjected to a light field with only (m+1)2 directions even though the luminaire provides a light field with a nominal r2 number of directions.
The (m+1)2 directions cannot be directly encoded. More specifically, an individual light ray in the illumination field cannot be turned on or off directly, but instead, is controlled by turning on or off pixels in the pixel-layers. In other words, illumination direction coding is achieved via coding patterns that are displayed on the pixel-layers.
Accordingly, in the example of
The objective of the coding framework is to design a series of binary coded patterns to be displayed on multiple pixel-layers such that if a light ray {right arrow over (q1q2 )} causes a reflection observed by a pixel of an image capturing device, a sequence of readings at that camera pixel (when different patterns are displayed) would allow for the recovery of q2x−q1x and q2−q1y. These quantities in turn allow for a determination of the direction of {right arrow over (q1q2)}, but not a position. Because the admissible cone is one-sided, the signs of these quantities are predetermined, and it is sufficient to recover |q2x−q1x| and |q2y−q1y|.
It is typical for independent coded patterns to be designed for the x and y directions, i.e., the coded patterns are vertical and horizontal stripes respectively. The following description can be applied to either x or y direction, where qi is identified with q1x, and q1y, and q2 is identified with q2x and q2y, etc.
For an example n, a general method of designing n binary coded vertical striped patterns (respectively horizontal striped patterns) on r pixels on one pixel-layer in the horizontal direction (respectively in the vertical direction) is as follows. A mapping is first chosen where ψ: {0,1,2, . . . , r−1}→{0,1,2, . . . , 2n−1}. Then the n binary coded patterns at pixel q ∈{0,1,2, . . . , r−1} are given by the binary vector βn (Ψ(q)) ∈(Z/2Z)n, where βn denotes the conversion of a number to its binary bit vector representation. The Gray code (of which the standard Gray code, also called the reflected Gray code, is a special case) corresponds to the case that Ψ=ΨRGC is a permutation on the 2n symbols and successive code words βn (ΨRGC (q)) and βn (ΨRGC (q+1)) differ only in one coordinate or bit position.
The method in Tin et al. uses the reflected Gray code and can be considered a special case of this formulation where the patterns on two pixel-layers are given by two mappings Ψ1=2┌log
The general problem of determining suitable codes on two pixel-layers can be formulated as the problem of finding a suitable n and suitable mappings Ψ1, Ψ2 such that |q2−q1} is uniquely determined by βn (Ψ(q1))+βn (Ψ2(q2)). |q2−q1| is a difference in pixel location coordinates of pixels located on two of the multiple pixel-layers. Thus, when a first pixel-layer displays n binary coded patterns that correspond to βn·Ψ1 and simultaneously a second pixel-layer displays n binary coded patterns that correspond to βn ·Ψ2 synchronization with the first pixel-layer in the sense that both pixel-layers are displaying the ith bit plane simultaneously, the combinations of the coded patterns correspond precisely to the vector sum of binary n-dimensional vector functions of the pixel coordinates βn ·Ψ1+βn ·Ψ2. Because a direction of light ray originating from the pixel-layers is uniquely identified by the difference |q2−q1|, solving this coding problem allows a direction of light ray originating from the pixel-layers to be uniquely identified by a combination of binary coded patterns.
Noting that the binary vector addition is component-wise mod 2 addition, or XORing (i.e., applying the exclusive-or operation), this models precisely the 90° rotation of polarization of light by each pixel-layer when the pixel-layers are comprised of LCD pixels. In other words, the binary vector sum is precisely what is recorded by the image capture device.
If Ψ1=Ψ2=ΨRCC is chosen, then by construction of the reflected Gray code, |q2−q1|=dH (βn (ΨRGC (q1)) βn (ΨRGC (q2)),0) if q2−q1=±2 , where dH is the Hamming distance. Using the reflected Gray code as the coding scheme, only m=2 can be chosen, i.e., the admissible cone has only (m+1)2=9 light rays.
Accordingly, there exist other more specialized Gray codes with better properties for purposes of the embodiments described herein. For example, Goddyn and Gvozdjak, “Binary Gray Codes with Long Bit Runs”, Electronic Journal of Combinatorics, 2003, describes certain long run Gray codes having a large minimum-run-length (MRL). If ΨGG denotes the associated mapping and m=mrl(ΨGG) its minimum-run-length, then |q2−q1|=dH(βn(ΨGG(q1))+βn(ΨGG(q2)),00 if |q2−q1≦m. In other words, by choosing m to be the minimum-run-length (MRL) of the binary Gray code, the minimum-run-length (MRL) of the binary Gray code determines a maximum difference in pixel location coordinates of pixels located on two of the multiple pixel-layers that can be encoded.
Using the long run Gray code of Goddyn and Gvozdjak, |q2−q1| is uniquely determined by βn(ΨGG(q1))+βn(ΨGG(q2)) if q2 lies within the admissible cone of q1.
In particular, a 10-bit code (i.e., n=10) can be constructed that has a minimum-run-length of m=8.
As shown in the figure, the front pixel-layer and the back pixel-layer are largely in parallel to each other. Example values of parameters for the system of
According to the above parameters, the system of
for resolving normal vectors. Use of 10-bit long run Gray code requires a minimum of 20 image captures (horizontal and vertical stripes based on the 10-bit Goddyn-Gvozdjak “long run” Gray code simultaneously displayed on the two pixel-layers). To the contrary, if the method described in Tin, et al. is applied to this setup, then a theoretical minimum of 28 image captures is required (horizontal and vertical stripes based on the 7-bit reflected Gray code displayed separately on each pixel-layer).
Also described in Tin, et al. is the use of inverse patterns for more robust binarization of the captured images. This can also be implemented in the coding scheme of the example embodiments described herein. More specifically, using the identity ˜xor(x, y)=xor(˜x, y)=xor(x,˜y), the binary patterns can be inverted on one of the pixel-layers. Using these extra coded patterns, the number of image captures required is 40, whereas the number of image captures required in the method of Tin, et al. is 56.
Briefly, in
In step S601, an object is positioned relative to a luminaire such that the object lies within the admissible region of the luminaire. In further embodiments described more fully below, a plurality of luminaires may also be used, and the object is positioned within the admissible region of the plurality of luminaires. The admissible region of the plurality of luminaires is the intersection of all admissible regions of the individual luminaires.
In step S602, multiple coded patterns, based on the encoding framework described above (e.g., based on the long run Gray code), are displayed simultaneously and in synchronization with each other on each pixel-layer of the luminaire such that combinations of the multiple coded patterns (e.g., combinations resulting from XORing of binary patterns or component-wise addition of binary vectors) uniquely identify directions of light rays originating from the multiple pixel-layers, and one or more images are captured of the object as it is illuminated by the multiple coded patterns.
In step S603, a unique incident light ray direction for each pixel of the captured one or more images is determined by decoding the combinations of the multiple coded patterns. Decoding the combinations of the multiple coded patterns includes recovering the XORed binary patterns from the captured images. While the individual patterns before XORing cannot be recovered from the captured images, the XORed binary patterns can be recovered from the capture images. This typically involves binarizing the captured images, i.e., conversion of the captured color or grayscale images into binary, black and white images. Each binarized image corresponds to a recovered bit plane, and a full set of n binarized images corresponds to a full set of n bit planes, which is precisely the image βn·Ψ1+βn·Ψ2.
In step S604, a surface normal vector field of the object is determined based on the determined unique incident light ray direction for each of the one or more pixels of the one or more captured images, for example, by calculating the half-way vector between the incident light ray direction and the viewing direction from a camera for each of the one or more pixels of the one or more captured images, or by using the methods described previously in Tin et al.
In step S605, the surface geometry of the object is recovered by determining points on the surface of the object from the determined surface normal vector field, or by triangulation of the unique incident light ray direction and a viewing direction from a camera for each of the one or more pixels of the one or more captured images.
In one embodiment, the depth map of the object is recovered by integrating the determined normal vector field. More specifically, the gradients ∂H/and ∂x and ∂H/∂y are determined from the normal vector field, where H(z) is in turn a function of the depth z. In the case of an orthographic camera, H(z)=z, whereas in the case of a perspective camera, H(z)=lnz. In either case, integration of the gradient field recovers H(z) and, in turn, depth z.
In another embodiment, points on the surface of the object are determined by triangulation. Generally, if the incoming illumination ray is represented parametrically by x=p+tu where p is a 3D point, u is a unit vector and t is a free parameter, and similarly the viewing ray is represented parametrically by x=q+sv where q is a 3D point, v is a unit vector and s is a free parameter, then the surface point can be estimated by the method of triangulation as q+s0v, where w=q−p, and
The estimated point is the 3D point on the viewing ray that is closest to the illumination ray. The depth value of this 3D point is then taken as the depth value of the point on the surface of the object.
In the previous section, a single luminaire is used to encode (m+1)2 illumination directions. For m=8, this is limited to only 81 directions. To alleviate this limitation, a design using a plurality of luminaires surrounding the object has been considered.
More specifically, an 8×8 array of luminaires each consisting of pixel-layers of pixel resolution 128×128 are deployed such that the resultant admissible region is the intersection of admissible regions of the luminaires and such that the luminaires surround the resultant admissible region within which the object is to be placed.
In the system of
Because the total number of pixels is 1024×1024, the same 10-bit “long run” Gray code can be spread out across multiple luminaires. However, in order to identify which luminaire an individual light ray originates from, it is necessary to use an extra 2×3=6 patterns (because 23×23 is the number of luminaires). In an example embodiment, the most significant 3 bits of the standard 10-bit reflected Gray code are used to generate these additional vertical and horizontal stripe patterns.
The following Table I is a comparison of the number of image captures required in the system of
For the purpose of measuring the surface normal vector field of the object, the final steps are as follows. The above-described pattern coding allows for the recovery of the unique incident light direction for a specular reflection that a camera pixel records. Assuming that the camera is geometrically calibrated, the camera ray (i.e. camera viewing direction) for the pixel can be determined. The normal vector is then recovered as the half-way vector between the incident light direction and the camera viewing direction.
Additionally, Tin et al. describes spectral multiplexing for color displays as a way to further reduce the number of required image captures by a factor of C, where C is the number of color channels. Because color filters do not change the polarization state, the layers still combine in each color channel according to the XOR logical operation. Accordingly, the above-described methods of illumination direction coding can take advantage of spectral multiplexing as well.
In this 2D case, the number of required image captures is 13. Implementation using the standard reflected Gray code of Tin, et al. requires 20 image captures. The two methods yielded identical results, confirming that when the object is located within the admissible region, light rays that do not reach the admissible region have no effect on the results of the measurements.
Out of 512 camera pixels, 92 pixels capture a reflection. The surface normal vectors for these 92 pixels are reconstructed.
According to other embodiments contemplated by the present disclosure, example embodiments may include a computer processor such as a single core or multi-core central processing unit (CPU) or micro-processing unit (MPU), which is constructed to realize the functionality described above. The computer processor might be incorporated in a stand-alone apparatus or in a multi-component apparatus, or might comprise multiple computer processors constructed to work together to realize such functionality. The computer processor or processors execute a computer-executable program (sometimes referred to as computer-executable instructions or computer-executable code) to perform some or all of the above-described functions. The computer-executable program may be pre-stored in the computer processor(s), or the computer processor(s) may be functionally connected for access to a non-transitory computer-readable storage medium on which the computer-executable program or program steps are stored. For these purposes, access to the non-transitory computer-readable storage medium may be local such as by access via a local memory bus structure, or may be remote such as by access via a wired or wireless network or Internet. The computer processor(s) may thereafter be operated to execute the computer-executable program or program steps to perform functions of the above-described embodiments.
According to still further embodiments contemplated by the present disclosure, example embodiments may include methods in which the functionality described above is performed by a computer processor such as a single core or multi-core central processing unit (CPU) or micro-processing unit (MPU). As explained above, the computer processor might be incorporated in a stand-alone apparatus or in a multi-component apparatus, or might comprise multiple computer processors constructed to work together to perform such functionality. The computer processor or processors execute a computer-executable program (sometimes referred to as computer-executable instructions or computer-executable code) to perform some or all of the above-described functions. The computer-executable program may be pre-stored in the computer processor(s), or the computer processor(s) may be functionally connected for access to a non-transitory computer-readable storage medium on which the computer-executable program or program steps are stored. Access to the non-transitory computer-readable storage medium may form part of the method of the embodiment. For these purposes, access to the non-transitory computer-readable storage medium may be a local access such as by access via a local memory bus structure, or may be a remote access such as by access via a wired or wireless network or Internet. The computer processor(s) is/are thereafter operated to execute the computer-executable program or program steps to perform functions of the above-described embodiments.
The non-transitory computer-readable storage medium on which a computer-executable program or program steps are stored may be any of a wide variety of tangible storage devices which are constructed to retrievably store data, including, for example, any of a flexible disk (floppy disk), a hard disk, an optical disk, a magneto-optical disk, a compact disc (CD), a digital versatile disc (DVD), micro-drive, a read only memory (ROM), random access memory (RAM), erasable programmable read only memory (EPROM), electrically erasable programmable read only memory (EEPROM), dynamic random access memory (DRAM), video RAM (VRAM), a magnetic tape or card, optical card, nanosystem, molecular memory integrated circuit, redundant array of independent disks (RAID), a nonvolatile memory card, a flash memory device, a storage of distributed computing systems and the like. The storage medium may be a function expansion unit removably inserted in and/or remotely accessed by the apparatus or system for use with the computer processor(s).
This disclosure has provided a detailed description with respect to particular representative embodiments. It is understood that the scope of the appended claims is not limited to the above-described embodiments and that various changes and modifications may be made without departing from the scope of the claims.