1. Field of the Invention
The disclosure relates generally to image display adaptation, and, more particularly to content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images.
2. Description of the Related Art
The rapid deployment of stereoscopic equipment like displays and cameras will soon lead to a demand for users to be able to manipulate stereoscopic media similar to the way they manipulate 2D media. Stereoscopic media delivers not only an additional dimension and added enjoyment, but also additional challenges and constraints in creating a comfortable and enjoyable 3D experience. Because they do not address these constraints, naive extensions of existing 2D media manipulation algorithms usually fail to deliver a comfortable 3D viewing experience. Thus, nontrivial adjustments are often required to accommodate new constraints and take advantage of new opportunities.
Most stereoscopic displays rely on the principle of stereopsis, in which human eyes are horizontally separated and the separation causes an interocular difference in the images projected onto the left and right retinas. When each eye is presented with the proper image, humans perceive depth by fusing the left and the right images. The fusibility of stereoscopic images depends not only on properly calibrated displays but also depends heavily on perfect matches between the left and right images. Mismatches in image pairs, or binocular asymmetries, can lead to serious viewing discomfort. In severe cases, the user experiences diplopia (double vision) and 3D scene perception is totally disrupted or highly inaccurate. Even if the user is able to perceive a consistent 3D view, the effort required to resolve conflicts caused by binocular imperfections can lead to serious fatigue, eyestrain, and headache, and may reduce the sense of realism. Such mismatch is often caused by asymmetrical optical geometry or photometric characteristics. For example, the viewer may experience viewing discomfort if the left and the right images are misaligned horizontally.
Due to the diversity among display resolutions and aspect ratios, similar to 2D media, binocular images require adaptation to be displayed properly on different devices. In addition to adapting to the device resolution and aspect ratio (retargeting along the x and y directions on the screen plane), for stereoscopic displays, we often must adapt images to its comfort zone (that is, depth adaptation along the z direction perpendicular to the display). In addition to adapting to different displays, depth adaptation is often required for binocular images with excessive depth ranges.
Recently, the problem of 2D image and video retargeting, that is, adapting the images or videos for displays with different sizes and aspect ratios, has received considerable attentions. While traditional scaling and cropping methods can easily cause significant distortions or information loss, modern content-aware approaches take into account the saliency distribution of the image and attempt to keep the salient features uncontaminated. These approaches can roughly be categorized as discrete approaches or continuous approaches. The seam carving method is a well-known discrete approach that uses dynamic programming to find the optimal seam to be removed in an image according to its saliency map. A seam is a path of pixels from top to bottom or side to side. However, because of their discrete nature, those approaches do not preserve structured objects well, and lead to disturbing artifacts. For continuous approaches, several warping-based methods have been proposed. These methods treat retargeting as a mesh deformation/warping problem, in which prominent regions are constrained so that their shapes are preserved as much as possible while less salient areas are allowed to be distorted more. The optimal warping field is usually obtained by minimizing certain energy functions. A direct application of these 2D content-aware retargeting algorithms to binocular images could, however, lead to visual discomfort because the binocular disparity cues in the input are not properly preserved. Moreover, stereoscopic content introduces an additional retargeting dimension along the depth axis.
For retargeting along the depth axis, or controlling depth perception in the 3D content, researchers in the stereoscopic display community have proposed a variety of techniques, such as false eye separation, alpha-false eye separation, image scaling, image shifting, view scaling, etc. Unfortunately, none of these methods is content-aware, and hence they may cause large distortions on the image plane. Because most methods use global image transformations, they have limited control over depths or disparities. For example, an approach suggested using a uniform adaptation that scales the image uniformly. However, this can lead to distortion of the object shape if the horizontal and vertical scaling factors are different. Moreover, the perceived depth range varies with the scaling factor.
Content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images are provided. The present method first detects a sparse set of robust correspondence points and then optimizes the warping fields of the image pair according to the target display parameters, correspondence constraints, and other constraints that prevent the results from distortions. The present method can achieve various retargeting scenarios, including changing the display size, aspect ratio, allowable depth range, and viewing configuration. It can also achieve effects not supported in traditional depth adaptation methods, such as changes to the scene depth that do not affect its scale. In addition, by modeling the user interaction as constraints, the present system can be extended to an interactive stereoscopic image editing system. The user can specify the transformation of the disparity/depth values, and the system accordingly warps the input to generate a new stereoscopic image. The user can also select a single object and specify its position, depth, or even explicit 3D location. The system automatically identifies the depths of other regions and warps the input to match user's intention. The resultant system is the first content-aware system to simultaneously allow retargeting, depth adaptation, and interactive editing of stereoscopic images.
In an embodiment of a content-aware display adaptation method for stereoscopic images for use in an electronic device, stereoscopic images comprising at least one image pair of a left image and a right image are provided. Then, saliency maps are estimated for the image pair using a graph-based visual saliency algorithm. Each image is represented as a grid mesh and a per-quad importance is measured for each quad based on the saliency maps. Features of the left image and the right image are detected, and the detected features are matched between the left image and the right image. An energy function is defined according to the saliency maps, the matched features, data for the grid mesh, and specification of a target display, wherein the energy function consists of at least a disparity consistency energy, which ensures the disparities of the matched features are manipulated in a consistent way. Then, the energy function is minimized to obtain two sets of deformed vertex positions for the left image and the right image.
In an embodiment of a content-aware display adaptation method for stereoscopic images for use in an electronic device, stereoscopic images comprising at least one image pair of a left image and a right image are provided. Then, saliency maps are estimated for the image pair using a graph-based visual saliency algorithm. Each image is represented as a grid mesh and a per-quad importance is measured for each quad based on the saliency maps. Features of the left image and the right image are detected, and the detected features are matched between the left image and the right image. An energy function is defined according to the saliency maps, the matched features, data for the grid mesh, and specification of a target display, wherein the energy function consists of at least an alignment energy, which ensures the features are horizontally aligned on the same scanline after deformation. Then, the energy function is minimized to obtain two sets of deformed vertex positions for the left image and the right image
In some embodiments, SIFT (Scale Invariant Feature Transform) features are detected from both the left image and the right image, and the matched features are verified using a fundamental matrix estimated using RANSAC (RANdom SAmple Consensus). In some embodiments, cluttered features are further removed from the detected features using non-maximum suppression.
In some embodiments, the disparity consistency energy comprises a global scaling factor of disparity and a shift factor, which are used to maintain the relative depths of the features.
In some embodiments, the energy function further consists of at least an alignment energy, which ensures the features are horizontally aligned on the same scanline after deformation.
In some embodiments, the energy function further consists of at least a distortion energy and a line bending energy, wherein the distortion energy prevents important quads in the grid mesh from being non-uniformly scaled, and the line bending energy maintains the angle between an original edge and an deformed edge corresponding to each quad to be as small as possible.
In an embodiment of an editing method for stereoscopic images for use in an electronic device, an operational interface is displayed on a touch-sensitive display unit of the electronic device, wherein the operational interface displays stereoscopic images comprising at least one image pair of a left image and a right image, and has at least one control indicator. An input corresponding to the control indicator is received via the touch-sensitive display unit. An energy function is modified based on the input, wherein the energy function is defined according to saliency maps, matched features for the stereoscopic images, data for a grid mesh corresponding to each image, and specification of the touch-sensitive display unit. The energy function is minimized to obtain two sets of deformed vertex positions of the grid mesh for the left image and the right image. Then, the deformed stereoscopic images are displayed on the touch-sensitive display unit based on the deformed vertex positions.
In some embodiments, the energy function consists of at least a disparity consistency energy, which ensures the disparities of the matched features are manipulated in a consistent way, and the disparity consistency energy comprises a global scaling factor of disparity or a shift factor, which are used to maintain the relative depths of the features, in which the control indicator corresponds to the global scaling factor or the shift factor.
In some embodiments, the input is performed by touching and scrolling the control indicator of the operational interface on the touch-sensitive display unit.
Content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images may take the form of a program code embodied in a tangible media. When the program code is loaded into and executed by a machine, the machine becomes an apparatus for practicing the disclosed method.
The invention will become more fully understood by referring to the following detailed description with reference to the accompanying drawings, wherein:
Content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images are provided.
Before explaining the present invention, the basic model for stereovision, in particular the relationship between perceived depth and image disparity is introduced, and the problem of stereoscopic image retargeting is then formulated.
A stereoscopic display delivers two different images to two eyes, and the viewer's brain fuses these images to achieve 3D perception. Therefore, to have a perception of point P at [Xp, Yp, Zp]T in 3D space, its projection is pL=[xpL, yp]T on the left image and pR=[xpR, yp]T on the right image, where
The horizontal shift of pixel p between the left and right eyes, dp=xpR−xpL, is usually denoted as disparity and is related to its depth Zp by
Similarly, given the two corresponding points pL=[xpL, yp]T and pR=[xpR, yp]T on the left and right images, the viewer perceives a 3D point P at [Xp, Yp, Zp]T:
In particular, the perceived depth Zp of the point is related to the disparity dp as
From Eq. (6), it is shown that the perceived depth is related nonlinearly to disparity.
It is noted that, when the image is transformed, the disparities change subtly. When the image is stretched linearly along the x-axis, the disparities increase linearly. However, the disparities are unaffected by y-axis stretch. Therefore, when the real estate of the display increases, the depth range of the displayed image increases accordingly. In the worst case, the object can be pushed beyond infinity (i.e., dp>e in Eq. (6)), leading to an incorrect and irritating 3D effect. Similarly, when the aspect ratio changes, the disparities change accordingly. These phenomena seriously hinder the distributions of stereoscopic content across different medium. For example, a striking 3D effect in the cinema may look flat and boring on a 3D mobile phone, and a 3D effect that looks good on a mobile phone may lead to diplopia in the cinema.
Another crucial parameter of a stereoscopic display is its comfort depth range, or called comfort zone. When viewing a stereoscopic display, our eyes fixate on the virtual 3D object, providing the convergence cue for 3D perception. We must focus on the screen for sharp images, in which the lack of an accommodation cue (change of focus) informs the brain that the display is flat. This conflict between accommodation and convergence cues causes visual discomfort, especially for excessive disparity values. Thus the comfort zone is that range of depths where the conflict can be tolerated. Depth outside that zone can cause diplopia or blur. Because of optics properties, viewing distances, and other factors, different displays have different comfort zones. Even for the same viewing configuration, the comfort zone can vary among individuals.
For these reasons, depth adaptation is required to ensure a vivid and enjoyable 3D experience. Given a stereoscopic image pair captured for a specific viewing configuration, the depth adaptation process attempts to adjust the content, such that the 3D perception delivered in another viewing configuration is identical or similar to the original one. The method most commonly used in commercial stereo displays is the image shifting method. By horizontally shifting one of the images, we can increase/decrease the disparities and thus the depths. However, because the mapping between the disparity and 3D coordinate is nonlinear, this simple method causes undesirable miniaturization or gigantism effects. Thus, when image shifting is used to adjust the binocular image, the perceived scene scale changes accordingly as an unwanted side effect. Other methods that rely on global image transformations have the same drawback.
Theoretically, for perfect depth adaptation, one should first reconstruct the scene from the input images, transform the scene to fit the display comfort zone, and finally re-project the scene to obtain the new stereoscopic images. However, this approach requires dense scene geometry, which is typically noisy or even unavailable. Moreover, in the scene transformation and re-projection process, the system must recover scene content occluded in the original input, which itself is a challenging and unsolved research problem. One solution is to sample more data during acquisition by using multi-rigging techniques or camera arrays, which allow for better scene reconstruction. If the footage is computer-generated, it is possible to re-render it for each display. However, these approaches are expensive for amateurs. Another solution is to edit the stereoscopic content by manual authoring, which can be very time-consuming. As described, the present method can avoid these difficulties and still generate appealing results.
In step S2100, stereoscopic images comprising at least one binocular image pair {IL, IR} of a left image and a right image are provided. In step S2200, saliency maps {φL, φR} are estimated for the image pair {IL, IR} using a saliency detection algorithm. It is noted that, the saliency maps {φL, φR} shows the pre-pixel importance of the image pair {IL, IR}. It is understood that, in some embodiments, the saliency detection algorithm may be a graph-based visual saliency algorithm, such as a frequency-tuned salient region detection method. It is noted that, the frequency-tuned salient region detection method is an example of the present invention, and the present invention is not limited thereto. In step S2300, each image is represented as a grid mesh and a per-quad importance is measured for each quad based on the saliency maps {φL, φR}. It is understood that, in some embodiments, the per-quad importance for each quad is measured by averaging and normalizing the per-pixel saliency based on the saliency maps {φL, φR}. Then, in step S2400, features of the left image and the right image are detected, and the detected features are matched between the left image and the right image. It is noted that, in some embodiments, SIFT (Scale Invariant Feature Transform) features are detected from both the left image and the right image. For each feature point in IL, its best match in IR is found and verified using a fundamental matrix estimated using RANSAC (RANdom SAmple Consensus). Further, in some embodiments, cluttered features can be removed from the detected features using non-maximum suppression. In step S2500, an energy function is defined according to the saliency maps, the matched features, data for the grid mesh, and specification of a target display. It is noted that, the energy function can comprise constrains for generation of warping fields. In the present method, the energy function consists of four parts: distortion energy Ψd , line bending energy Ψb, alignment energy Ψa, and disparity consistency energy Ψc. It is noted that, in the present method, the energy function can consist of at least one of the above energies. Details of the respective energy are discussed as follows. It is noted that, the set of n matched features is denoted as F={(fiL, fiR)|i=1 . . . n}, and {VL, EL, QL} and {VR, ER, QR} denotes the grid meshes for both images, where V, E and Q represent the vertex sets, edge sets, and quad face sets, respectively.
Distortion Energy
Distortion energy prevents important quads from being non-uniformly scaled. For each quad q with four edges E(q), the distortion energy for the quad is defined as
where sq is the scale factor defined by {tilde over (v)}i and vi. The total distortion energy is the weighted sum of the distortions of all quads in both views, which is defined as
where
Line Bending Energy
In addition to non-uniform scaling, the bending of the grid edges is minimized. That is, the angle between the original edge e and deformed edge {tilde over (e)} is expected to be as small as possible. It is understood that, in the present method, a new linear line bending energy is proposed. Consider edge e which has the two vertices vi and vj and its deformed version {tilde over (e)}=({tilde over (v)}i, {tilde over (v)}j). Vectors are defined, in which e=vi−vj and {tilde over (e)}={tilde over (v)}i−{tilde over (v)}j. The following term is used to approximate the angle between e and {tilde over (e)}:
Δ({tilde over (e)})=∥see−{tilde over (e)}∥2, (9)
where se is a scale parameter expected to be optimized. Taking the partial derivative of Δ with respect to se, the optimal se* is obtained as
s
e*=(eTe)-1eT{tilde over (e)}. (10)
Substituting se* back into Eq.(9) yields a function of {tilde over (e)}:
Where C=e(eTe)−1eT−I and I is the identity matrix.
Eq. (11) can be further rewritten as a function of {tilde over (v)}i and {tilde over (v)}j:
Finally, the total line bending energy is defined as
Alignment Energy
The alignment energy is used to ensure vertical alignment of features after deformation to avoid binocular asymmetries. The alignment energy Ψa is defined as:
where notation v[y] represents the y component of the vector v, and similarly v[x] for the x component.
Note that, the relocated feature {tilde over (f)} can be expressed as a linear combination of the vertices after deformation {tilde over (v)}i using barycentric coordinates. It is assumed that, before deformation, the feature f is related to the vertices vi of the quad where it is located in as f=Σi=14βivi, where βi are the barycentric coordinates. The relocated feature {tilde over (f)} can then be written as a linear combination of deformed vertices, {tilde over (f)}=Σ1=14βi{tilde over (v)}i, using the same barycentric coordinates. Therefore, Eq. (14) can be written as a function of the warped vertices {tilde over (v)}i.
Disparity Consistency Enemy
Disparity consistency energy is used to ensure that the disparities of features are manipulated in a consistent way to avoid distortion of the perceived depths. Two different disparity consistency energies are provided, in which each of which is useful for different applications. The first energy is an attempt to keep the perceived depths identical to those before deformation. This is useful for the situation when the image size changes while the viewing configuration is the same. In such cases, the same disparity is expected to be maintained, so that the perceived depth is the same after resizing. For this option, the disparity consistency energy Ψc is defined as
where di=fiR[x]−fiL[x] and {tilde over (d)}i={tilde over (f)}iR[x]−{tilde over (f)}iL[x] are the disparity values in the pixel domain before and after deformation respectively.
In cases in which viewing configurations change, the disparity values should be scaled and shifted accordingly. Thus, for the second option, the relative depths of the feature points in the input images are expected to be maintained by finding a monotonic increasing mapping of depths. In this way, the depth order of the objects is preserved but their absolute depths are flexible. A trivial choice is to find a proper 1D similarity transform of depths to maintain the relative depths. However, this makes the energy term nonlinear to deformed features. We choose instead to find a proper 1D similarity transformation of disparities to maintain the relative depths:
Where sd represents the global scaling factor of disparity and td represents the shift. Using the same approach used to obtain the optimal se* in Eq. (9), sd and td, can be eliminated from Eq. (16) and turned into a function of deformed features, each of them a linear combination of deformed vertices. After defining matrix E and vector {tilde over (E)} as
Eq. (16) is re-written as
and the optimal scale sd* and shift td* are
By substituting sd* and td* back into Eq. (17), the energy Ψc can be written as a function of deformed features:
where B=E(ETE)−1ET-I, A=[−I|I] and
Again, {tilde over (f)} can be rewritten in terms of the deformed vertices. Note that the optimal scale and shift can be integrated into the energy function and determined automatically by optimization.
As described, the energy function can consist of at least one of the above energies. In some embodiments, the final energy Ψ is the sum of the four defined energy terms:
Ψ=Ψd+λbΨb+λa+λcΨc. (20)
In some embodiments, the coefficients can be set as: λb=1, λa=10 and λc=500. The above energy function is an interplay between 2D shape conservation and depth preservation.
After the energy function is defined, in step S2600, the energy function is minimized to obtain two sets of deformed vertex positions for the left image and the right image. It is understood that, these terms are all functions of the deformed grid vertices {tilde over (v)}iL and {tilde over (v)}iR. Minimizing Ψ corresponds to solving a least-squares problem and leads to a linear system involving only {tilde over (v)}iL and {tilde over (v)}iR. By finding the sets of deformed vertices {tilde over (v)}iL and {tilde over (v)}iR which minimize Ψ and satisfy the boundary conditions, both images are warped to the target resolution while maintaining the 3D shapes of important objects. Then, the full warping fields are interpolated using bilinear interpolation according to the deformed vertex positions and the input image pair.
An example follows.
In step S4100, an operational interface is displayed on a touch-sensitive display unit of the electronic device. The operational interface displays stereoscopic images comprising at least one image pair of a left image and a right image, and has at least one control indicator. It is noted that, the at least one control indicator corresponds to at least one factor in an energy function. In step S4200, it is determined whether an input corresponding to the control indicator is received via the touch-sensitive display unit. It is understood that, in some embodiments, the input is performed by touching and scrolling the control indicator of the operational interface on the touch-sensitive display unit. If no input is received (No in step S4200), the procedure remains at step S4200. If an input corresponding to the control indicator is received via the touch-sensitive display unit (Yes in step S4200), in step S4300, an energy function is modified based on the input. It is noted that, the energy function is defined according to saliency maps, matched features for the stereoscopic images, data for a grid mesh corresponding to each image, and specification of the touch-sensitive display unit, and the energy function comprises distortion energy Ψd, line bending energy Ψb, alignment energy Ψa, and/or a disparity consistency energy Ψc. It is noted that, in the present method, the energy function can consist of at least one of the above energies. The details of the energy function and the corresponding energies are omitted here. In some embodiments, the factor corresponding to the control indicator may be the global scaling factor and/or the shift factor in the disparity consistency energy. The input corresponding to the control indicator can be used to modify the optimal value for the factor. Then, in step S4400, the energy function is minimized to obtain two sets of deformed vertex positions of the grid mesh for the left image and the right image. Similarly, minimizing Ψ corresponds to solving a least-squares problem and leads to a linear system involving only {tilde over (v)}iL and {tilde over (v)}iR. By finding the sets of deformed vertices {tilde over (v)}iL and {tilde over (v)}iR which minimize Ψ and satisfy the boundary conditions, both images are warped to the target resolution while maintaining the 3D shapes of important objects. Then, in step S4500, the deformed stereoscopic images are interpolated using bilinear interpolation according to the deformed vertex positions and the input image pair, and displayed on the touch-sensitive display unit.
Furthermore, the present application can be extended to interactively edit depths of the whole scene or even a region in images. Note that it is more natural to edit depths than disparities. Thus, Eqs. (1-3 and 5) can be used to convert between depths and disparities. A graphical user interface (GUI) for interactive and direct manipulation of the stereoscopic images can be provided. In the GUI, a main window shows the editing image, and can freely switch between the original input and the edited result. Depending on the display capability, it can also switch to the left view, the right view, the anaglyph image, and the binocular image, which allows the user to view the 3D effect during editing. The user can simply drag the image boundary to adjust the size and aspect ratio, and the system displays the retargeting image interactively. Several different visualization methods are provided for depth adaptation or adjustment. The GUI shows the 3D spatial distribution of the feature points from the side and from the top. It can also display the comfort zone, and the sorted depth distribution of feature points. The comfort zone is an optional input which is found either in the specification of the target display or is determined empirically. Several options can be provided for editing depths. In the first option, the user can either specify a similarity transformation or directly draw the desired target depth distribution in the depth distribution view. The system automatically calculates the resulting disparity value for each feature point. In the second option, the user can select an area by drawing a bounding polygon and edit its 3D position and scaling factor. In all these editing operations, the system can generate the warped result and update the disparity distribution and feature locations immediately.
As mentioned, in the first option, the user first specifies the desired depth transformations for all features. This can be done by specifying 1) a 1D similarity transformation of depths, or 2) the target depth distribution. The system then converts the depths to the corresponding disparities and incorporates them into the disparity consistency energy Ψc.
It is assumed that, a similarity transformation is used. First, the disparities di of all features F={fi} are converted from the pixel domain to the physical domain. Next, the depths Zi are calculated from their disparities di using Eq. (6),
The target depth {circumflex over (Z)}i is calculated as {circumflex over (Z)}i=szZi+tz and then converted back as the target disparity
using Eq. (4). After converting {circumflex over (d)}i from the physical domain to the pixel domain, the disparity consistency energy is then modified using the target disparities as
If the target depth distribution is specified, the target depths {circumflex over (Z)}i are given by the user and the resulting procedure is similar. The present method also allows users to change the size and position of the object. First, the user selects features on the object by drawing a closed region. The user can then input the 3D scaling factor (sx, sy, sz) and translations (tx, ty, tz) for this object. The set of selected features {circumflex over (F)}=(fiL, fiR) is projected back to its 3D position (Xi, Yi, Zi) using Eq. (5). Scaling and translating the 3D position accordingly yields the target 3D position {circumflex over (X)}i, Ŷi, {circumflex over (Z)}i, which are projected onto both views to obtain {circumflex over (f)}iL and {circumflex over (f)}iR using Eqs. (1-3). For the remaining features, either Eq. (15) or (16) is used as the constraint. It is assumed that Eq. (16) is used, the disparity consistency energy is then modified as
where λ is the weight between these two parts of energy (λ is set as 0.1). Finally, Ψ with the modified Ψc is minimized to deform the images to match the above constraints in a content-aware manner.
Therefore, the content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images can simultaneously resizes a binocular image to the target resolution and adapts its depth to the comfort zone of the display while preserving the perceived shapes of prominent objects. The present method does not require depth information or dense correspondences. Given the specification of the target display and a sparse set of correspondences, the present method can efficiently deform the input stereoscopic images for display adaptation, for example, by solving a least-squares energy minimization problem. This can be used to adjust stereoscopic images to fit displays with different real estates, aspect ratios, and comfort zones. In addition, with slight modifications to the energy function, the present method allows users to interactively adjust the sizes, locations, depths of the selected objects, and/or related factors of the energy function, giving users aesthetic control for depth perception.
Content-aware display adaptation methods and related editing interfaces and methods for stereoscopic images, or certain aspects or portions thereof, may take the form of a program code (i.e., executable instructions) embodied in tangible media, such as floppy diskettes, CD-ROMS, hard drives, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine thereby becomes an apparatus for practicing the methods. The methods may also be embodied in the form of a program code transmitted over some transmission medium, such as electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the disclosed methods. When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates analogously to application specific logic circuits.
While the invention has been described by way of example and in terms of preferred embodiment, it is to be understood that the invention is not limited thereto. Those who are skilled in this technology can still make various alterations and modifications without departing from the scope and spirit of this invention. Therefore, the scope of the present invention shall be defined and protected by the following claims and their equivalent.