USRE43490E1 - Wide-angle dewarping method and apparatus - Google Patents

Wide-angle dewarping method and apparatus Download PDF

Info

Publication number
USRE43490E1
USRE43490E1 US12/118,570 US11857008A USRE43490E US RE43490 E1 USRE43490 E1 US RE43490E1 US 11857008 A US11857008 A US 11857008A US RE43490 E USRE43490 E US RE43490E
Authority
US
United States
Prior art keywords
image
control points
perspective corrected
distorted image
vectors
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related, expires
Application number
US12/118,570
Inventor
Eric Gullichsen
Susan P. Wyshynski
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Chartoleaux KG LLC
Original Assignee
BH Image Co LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US08/250,594 external-priority patent/US5796426A/en
Application filed by BH Image Co LLC filed Critical BH Image Co LLC
Priority to US12/118,570 priority Critical patent/USRE43490E1/en
Assigned to B.H. IMAGE CO. LLC reassignment B.H. IMAGE CO. LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BE HERE CORPORATION
Application granted granted Critical
Publication of USRE43490E1 publication Critical patent/USRE43490E1/en
Assigned to CHARTOLEAUX KG LIMITED LIABILITY COMPANY reassignment CHARTOLEAUX KG LIMITED LIABILITY COMPANY MERGER (SEE DOCUMENT FOR DETAILS). Assignors: B.H. IMAGE CO. LLC
Adjusted expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T3/00Geometric image transformations in the plane of the image
    • G06T3/04Context-preserving transformations, e.g. by using an importance map
    • G06T3/047Fisheye or wide-angle transformations
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/222Studio circuitry; Studio devices; Studio equipment
    • H04N5/262Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
    • H04N5/2628Alteration of picture size, shape, position or orientation, e.g. zooming, rotation, rolling, perspective, translation

Definitions

  • the present invention relates to a method and apparatus for displaying a perspective corrected field of view from wide angle video sources, and more particularly relates to permitting the user of an orientation sensing means to view a selected portion of stored or real time video encoded from a wide angle source and transforming that portion to a perspective-corrected field of view.
  • VR virtual reality
  • Telepresence a user is permitted to view a computer-generated graphical representation of a selected environment. Depending on the sophistication of the hardware and software used to generate the virtual reality environment, the user may be treated to a three dimensional view of the simulated environment.
  • Telepresence a user is permitted to view a real-world, live or recorded environment from a three dimensional perspective.
  • the user is permitted to see different portions of the VR and telepresence environments simply by moving or orienting his head in one or more degrees of freedom. This permits the user to obtain the sensation that he is immersed in the computer-generated/real-world environment.
  • High end devices detect pan, roll and tilt motions by the user and cause the environment to change accordingly.
  • the pan ⁇ tilt ⁇ roll motions may be inputted by many types of input devices, such as joysticks, buttons or head orientation sensors (which may be connected to head mounted displays).
  • a continuing problem with the prior art is how to encode sufficient data that a viewer may arbitrarily move his viewing perspective within the telepresence environment and not look beyond the field of view.
  • One relatively simple solution, where the telepresence environment is based on a real three dimensional environment, is to simply use the head orientation sensors to cause a camera to track the orientation of the viewer. This has obvious limitations in that only one viewer can be in the telepresence environment at a time (since the camera can only track one viewer, and the other viewers will not typically be able to follow the head motions of the controlling viewer) and, also, prerecorded data cannot be used. Further, there is an inherent delay between a change in user viewing perspective and the time that it takes to realign the corresponding camera. These limitations greatly restrict the value of such systems.
  • One method for overcoming each of these limitations is to encode, either in real time or by pre-recording, a field of view largely equivalent to the entire range of motion vision of a viewer—that is, what the viewer would see if he moved his head in each permitted direction throughout the entire permissible range. For example, encoding substantially a full hemisphere of visual information would permit a plurality of viewers a reasonable degree of freedom to interactively look in a range of directions within the telepresence environment.
  • a typical approach for encoding substantially a full hemisphere of information involves using a fish-eye lens.
  • Fish-eye lenses by their nature, convert a three dimensional scene to a two-dimensional representation by compressing the data at the periphery of the field of view.
  • the visual data For the information to be viewed comfortably by a viewer in the VR environment, the visual data must be decompressed, or dewarped, so that it is presented in normal perspective as a two dimensional representation.
  • the present invention overcomes the limitations of the prior art.
  • the present invention transforms a plurality of viewing vectors within a selected portion of the wide angle, three dimensional video input into two dimensional control points and uses a comparatively simple method to transform the image between the control points to create a perspective-corrected field of view.
  • the present invention is drawn to a method and apparatus which provides perspective corrected views of live, prerecorded or simulated wide angle environments.
  • the present invention first captures a wide angle digital video input by any suitable means, such as through the combination of a high resolution video camera, hemispherical fisheye lens and real time digital image capture board.
  • the captured image is then stored in a suitable memory means so portions of the image may be selected at a later time.
  • a portion of the stored video When a portion of the stored video is selected, a plurality of discrete viewing vectors in three dimensional space are chosen and transformed into a plurality of control points in a corresponding two dimensional plane.
  • the area between the control points which is still warped from the original wide angle image capture, is then transformed into a perspective corrected field of view through a biquadratic polynomial mapping technique.
  • the perspective corrected field of view is then displayed on a suitable displaying apparatus, such as a monitor or head mounted display.
  • the present invention further has the ability to sense an inputted selection, orientation and magnification of a new portion of the stored video for transformation.
  • the present invention provides a dependable, low cost, faster and more elegantly simple solution to dewarping wide angle three dimensional images.
  • the present invention also allows for simultaneous dynamic transformation of wide angle video to multiple viewers and provides each user with the ability to access and manipulate the same or different portions of the video input.
  • the present invention also allows the computer generated three dimensional polygons to be rendered in advance; thus, users may view the environments from any orientation quickly and without expensive rendering hardware.
  • FIG. 1 shows a functional block diagram of one embodiment of the present invention.
  • FIG. 2 diagrams the geometry between three dimensional (X-Y-Z) space and its corresponding two dimensional (U-V) plane.
  • FIG. 3a shows a bilinear mapping of a warped image.
  • FIG. 3b shows a biquadratic mapping of a warped image.
  • FIG. 4 shows a side view of a viewing vector from a three dimensional (X-Y-Z) wide angle lens as it is seen on a two dimensional (U-V) plane.
  • FIG. 5 shows a three dimensional field of view along with a plurality of viewing vectors according to the present invention.
  • FIG. 6 shows a block diagram of the elements of a forward texture mapping ASIC according to the present invention.
  • FIG. 7 shows an example of a U-V source texture transformed into a X-Y plane destination texture according to the present invention.
  • FIG. 8 is one embodiment of how to obtain a 360 degree view using six hemispherical fisheye lenses according to the present invention.
  • FIG. 9 is a functional flow chart of one embodiment of the present invention.
  • a high resolution video camera 10 having a wide angle lens 20 such as a hemispherical fisheye lens, is directed to a real world scene 22 .
  • the output 24 of the camera 10 is provided to a real time image digitizing board 30 , commonly referred to as a “frame grabber,” located in or operatively connected to a conventional high speed computer indicated generally at 150 .
  • the camera 10 may be any camera which is capable of using a wide angle lens and providing suitable resolution. In most instances the camera will be a video camera, although in some instances it may be desirable to use a still frame camera.
  • the computer 150 is any computer capable of receiving and processing video information at an acceptable rate and may, for example, be an 80486-based or PentiumTM-based system, or other computer platform such as are made by Silicon Graphics, Sun Micro Systems, Apple Computer, or similar other computer manufacturers.
  • the fisheye lens 20 causes the video output signal 24 from the camera 10 to be optically warped in a non-linear manner. Before the image can be comfortably viewed by a user, perspective-correcting measures must be taken.
  • the digitized video signal 24 is thus transferred through the digitizing board 30 (typically but not necessarily operating at 30 frames per second) into memory 40 of the computer 150 so that portions of the video picture can be randomly accessed by a microprocessor 50 , also within the computer 150 , at any time.
  • the dewarping software is also stored in memory 40 and is applied to the video signal 24 by the microprocessor 50 .
  • the stored video signal is then transmitted from memory 40 to a special purpose ASIC 60 capable of biquadratic or higher order polynomial transformations for texture warping and interpolation.
  • the texture warping ASIC 60 may be omitted and its functionality may be performed by software. Phantom lines have been used to show the optional nature of ASIC 60 .
  • the perspective corrected video signal is next transmitted to a video output stage 70 , such as a standard VGA card, and from there displayed on a suitable monitor, head mounted display or the like 80 .
  • An input device 90 such as a joystick or headtracker (which senses the head movements of a user wearing a headmounted display), transmits position information through a suitable input port 100 , such as a standard serial, parallel or game port, to the microprocessor 50 to control the portion of the stored video that is selected, dewarped and displayed.
  • the input device 90 also transmits roll/pitch/yaw information to the microprocessor 50 so that a user may control the orientation of the dewarped video signal.
  • a magnification option could be added to the input device 90 to allow the user to magnify the selected portion of video input, constrained only by the resolution of the camera 10 .
  • FIG. 2 shows a real world three dimensional environment 200 which has been imaged by the wide angle lens 20 .
  • This environment is defined by the Cartesian coordinate system in X, Y and Z with the viewpoint defined to be the origin of the coordinate system.
  • the viewing direction of the user as defined by the input device 90 , is given as a viewing vector in the X-Y-Z coordinate system.
  • the image plane 210 containing the warped wide angle image is defined by a two dimensional coordinate system in U and V, with the origin of the coordinate system coincident with the origin of the X-Y-Z coordinate system. If the field of view of the lens 20 is sufficient, and the lens is rotationally symmetric about the viewing axis, the digitized warped image will be roughly circular in the U-V plane.
  • the first generation of ASICs developed for low-cost texture mapping of three dimensional graphics, mapped video images through a bilinear technique, such as is shown in FIG. 3(a) .
  • These chips were able to apply linear interpolation to texture pixels in both the X and Y directions and could thereby stretch rectangular source textures to any two dimensional quadrilateral shape.
  • An example of a chip of this type is the Artist Graphics 3GA chip.
  • These bilinear chips do, however, introduce texture errors for polygons whose vertices have been subject to significant amounts of perspective, and further are not capable of sufficiently high order texture distortion to adequately flatten extreme wide angle views, such as with hemispherical fisheye lenses.
  • FIG. 3b shows an example of a biquadratic technique, such as is now coming onto the market.
  • the preferred embodiment of the present invention uses an ASIC chip which implements a texture warping technique of at least second polynomial order.
  • the present invention is of sufficient simplicity that this technique could also be implemented in software on a general purpose high speed computer, such as a Silicon Graphics IndigoTM computer or a PentiumTM based computer.
  • the warped image in the U-V plane, shown in FIG. 2 has a radius 220 equal to RADIUS pixels with an origin at UORIGIN and VORIGIN.
  • Equations (1) convert an inputted X-Y-Z three dimensional viewing vector into a corresponding control point in the U-V plane.
  • N 2 in the above equations
  • a pseudo-inverse technique is used.
  • the values for a ij and b ij are then found by mapping the points in the U-V plane for the 3 ⁇ 3 grid of control points using the above equations (6).
  • the biquadratic polynomial transformations of the equations (3) are then used to transform the area between the control points.
  • the determination of the coordinates of each pixel in the U-V plane takes a total of thirteen multiplication and ten addition operations.
  • three of the required multiplication operations per pixel may be obviated by storing a table of xy, x 2 and y 2 values for each xy coordinate pair in the dewarped destination image.
  • the “x” values which do not vary as “y” changes (i.e.
  • a 1 *x+a 4 *x 2 and b 1 *x+b 4 *x 2 may also be precomputed and stored.
  • the “y” values which do not vary as “x” changes may be precomputed and stored.
  • the accuracy of the dewarping transformation will increase as the number of transformed viewing vectors increases, i.e. a 4 ⁇ 4 grid of control points will produce a more accurate transformation than a 3 ⁇ 3 grid of control points.
  • the amount of increase in accuracy quickly draws near an asymptote as the number of control points is increased.
  • One skilled in the art will recognize, therefore, that there is little reason in increasing the number of viewing vectors to more than half of the total number of pixels in the displayed region.
  • FIG. 9 shows a functional flow chart of the major elements of one embodiment of the present invention.
  • the fixed warped image parameters are defined, such as the size of the input image, the input image radius, and the input image center in U-V coordinates typically measured in pixels.
  • the next step 410 is to initialize the variable dewarped image parameters, such as the size of the dewarped image area, the horizontal and vertical field of views (generally shown in degrees), the creation of an untransformed view cone centered in this embodiment on the +Z axis and the initialization of the layout and number control points used therewith.
  • the next step is to load the precomputed inner-loop matrix values as well as the “xy” product terms, as shown in step 420 , to ensure that the transformation is accomplished as quickly and efficiently as possible.
  • the video signal is input to the system in any suitable form, i.e. live or pre-recorded real-time digitized video or computer synthesized video environments.
  • the system then allows the user to select the viewing vector (step 440 ) which in turn determines the portion of video which is to be transformed.
  • the control points are next transformed from the selected viewing vectors (step 450 ) and the region defined by the control points is dewarped (step 460 ).
  • the signal is then sent to the video buffer and to an appropriate viewing apparatus (step 470 ).
  • the loop also allows the user to make on-the-fly selections of alternate portions of the incoming video.
  • the same control points for the U-V plane map to the corners of the display screen in the X-Y plane.
  • the warped regions outside the bounding box may be clipped by hardware or software so that they are not visible on the display screen.
  • the source pixel coordinates which are fed from the host CPU, are converted to a ij and b ij coordinates for forward mapping in the forward mapping solution stage 240 , again using techniques mathematically equivalent to those of the equations (7).
  • a series of instructions is further sent from the host CPU to the chip 230 and received by a control unit 260 .
  • the control unit 260 sequences and controls the operation of the other functional stages within the chip 230 .
  • the host CPU also directs a linear sequence of source pixels, which are to be warped, to an interpolation sampler stage 250 within chip 230 .
  • these can be subject to a low-pass spatial prefiltering stage 270 prior to transmission to the chip, to reduce sampling error during the warping process.
  • the source pixels and the a ij and b ij coordinates are both fed to the interpolation sampler 250 .
  • the interpolation sampler 250 For each input pixel, one or more destination pixels together with their corresponding X-Y destination coordinates are produced. These warped pixels are then fed into the video frame buffer 280 , located outside of the ASIC chip 230 .
  • anti-aliasing circuitry 290 within the chip performs interpolation on output pixel values, such as bilinear interpolation between adjacent pixel samples, to minimize the effects of output spatial quantization error.
  • the techniques described herein may also be applied to synthetic images. Such images may be created entirely within a computer environment and may be composed of three dimensional geometrical descriptions of objects which can be produced by computer graphics rendering techniques generally known to those skilled in the art.
  • synthetic images are produced by linear perspective projection, emulating the physical process of imaging onto planar film with a lens having a narrow field of view and producing a view of the synthetic environment as seen through a cone or truncated three dimensional pyramid.
  • the color, intensity shading and other simulated physical properties of each pixel on the planar image grid can also be readily determined.
  • the viewing vectors in X-Y-Z space are rewritten in terms of the warped control points coordinates in the U-V plane
  • a direction vector in X-Y-Z space can thus be generated for each pixel in the U-V plane in the synthetic wide angle image which is created.
  • the generated vectors point in all directions within the created hemisphere, spaced to the limits of the resolution of the U-V image.
  • This technique can be used for the production of three dimensional modeled cartoons or interactive home gaming applications, among others.
  • the image substrate for recordation may be an electronic two dimensional image sensor, such as a CCD chip, or photographic film capable of chemically recording the image for subsequent transfer into digital form.
  • the present invention is not limited to transforming wide angle video onto a planar (U-V) surface, but that it is within the scope of the invention to transform wide angle video onto any suitable surface for displaying the video for the user.
  • two real world, wide angle lenses can be positioned opposite each other to permit near 360 degrees of total coverage of the environment. If seamless omnidirectional coverage of an environment is required, this could be achieved with six wide angle lenses positioned along each direction of a three dimensional axis, as shown in FIG. 8 .
  • This arrangement can be coupled with a video switching mechanism for choosing which signal is to be dewarped for the selected view and orientation of the video input.
  • the same video signal may be simultaneously transmitted to an arbitrarily large number of viewers all having the ability to simultaneously dewarp the same or different portions of the video input, as in the case of interactive cable TV viewing or multiple player online interactive video game playing.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Image Processing (AREA)

Abstract

A method and apparatus for transforming wide angle video into perspective corrected viewing zones which either a single user or multiple users may select, orient and magnify. The present invention first captures a wide angle digital video input by any suitable means. The captured image is then stored in a suitable memory means so portions of the image may be selected at a later time. When a portion of the stored video is selected for viewing, a plurality of discrete viewing vectors in three dimensional space are chosen on the video input and transformed to a plurality of control points in a two dimensional plane or any other suitable surface. The area between these points which is still warped from the original wide angle image capture is then transformed to a perspective corrected field of view. The perspective corrected field of view is then displayed on a suitable displaying apparatus, such as a monitor or head mounted display.

Description

This is a reissue of U.S. Pat. No. 7,042,497, which is a continuation of application Ser. No. 09/429,697, filed Oct. 28, 1999, now U.S. Pat. No. 6,346,967 which is a continuation of prior application Ser. No. 09/128,963, filed Aug. 4, 1998, U.S. Pat. No. 6,005,611, and which was a continuation of application Ser. No. 08/250,594 filed May 27, 1994, U.S. Pat. No. 5,796,426, incorporated herein by reference.
FIELD OF THE INVENTION
The present invention relates to a method and apparatus for displaying a perspective corrected field of view from wide angle video sources, and more particularly relates to permitting the user of an orientation sensing means to view a selected portion of stored or real time video encoded from a wide angle source and transforming that portion to a perspective-corrected field of view.
BACKGROUND OF THE INVENTION
“Virtual reality” and “telepresence” have become extremely popular for use in research, industrial and entertainment applications In “virtual reality”, or VR, a user is permitted to view a computer-generated graphical representation of a selected environment. Depending on the sophistication of the hardware and software used to generate the virtual reality environment, the user may be treated to a three dimensional view of the simulated environment. In “telepresence,” a user is permitted to view a real-world, live or recorded environment from a three dimensional perspective.
In addition, in some higher end systems the user is permitted to see different portions of the VR and telepresence environments simply by moving or orienting his head in one or more degrees of freedom. This permits the user to obtain the sensation that he is immersed in the computer-generated/real-world environment. High end devices detect pan, roll and tilt motions by the user and cause the environment to change accordingly. The pan\tilt\roll motions may be inputted by many types of input devices, such as joysticks, buttons or head orientation sensors (which may be connected to head mounted displays).
In VR applications, a continuing problem is how to render a three dimensional environment of the quality and speed users want while offering the product at a price they can afford. To make a realistic environment, such as in a three dimensional video game, many three dimensional polygons need to be rendered. This rendering requires prohibitively expensive hardware which greatly restricts the commercial value of such a system.
In relation to telepresence applications, a continuing problem with the prior art is how to encode sufficient data that a viewer may arbitrarily move his viewing perspective within the telepresence environment and not look beyond the field of view. One relatively simple solution, where the telepresence environment is based on a real three dimensional environment, is to simply use the head orientation sensors to cause a camera to track the orientation of the viewer. This has obvious limitations in that only one viewer can be in the telepresence environment at a time (since the camera can only track one viewer, and the other viewers will not typically be able to follow the head motions of the controlling viewer) and, also, prerecorded data cannot be used. Further, there is an inherent delay between a change in user viewing perspective and the time that it takes to realign the corresponding camera. These limitations greatly restrict the value of such systems.
One method for overcoming each of these limitations is to encode, either in real time or by pre-recording, a field of view largely equivalent to the entire range of motion vision of a viewer—that is, what the viewer would see if he moved his head in each permitted direction throughout the entire permissible range. For example, encoding substantially a full hemisphere of visual information would permit a plurality of viewers a reasonable degree of freedom to interactively look in a range of directions within the telepresence environment.
The difficulty with this approach is that most means for encoding such information distort, or warp, the visual data, so that the information must be corrected, or “de-warped” before a viewer can readily assimilate it. For example, a typical approach for encoding substantially a full hemisphere of information involves using a fish-eye lens. Fish-eye lenses, by their nature, convert a three dimensional scene to a two-dimensional representation by compressing the data at the periphery of the field of view. For the information to be viewed comfortably by a viewer in the VR environment, the visual data must be decompressed, or dewarped, so that it is presented in normal perspective as a two dimensional representation.
One solution to the distortion problem is proposed in U.S. Pat. No. 5,185,667 issued to Steven Zimmerman. The '667 patent describes an apparatus which effects camera control for pan, tilt, rotate and zoom while having no moving parts. Through the use of a fisheye lens and a complicated trigonometric technique, portions of the video images can be dewarped. However, the solution proposed by the '667 patent is impractical because it is insufficiently flexible to accommodate the use of other lenses besides a theoretically perfect hemispherical fisheye lens without the introduction of mathematical errors due to the misfit between the theoretical and the actual lens characteristics. This solution also introduces undesirable trigonometric complexity which slows down the transformation and is overly expensive to implement. This solution further maps each individual pixel through the complex trigonometric mapping formula further reducing the speed of the transformation from one coordinate system to another.
As a result, there has been a substantial need for a method and apparatus which can dewarp encoded wide angle visual data with sufficient speed and accuracy to permit a viewer to immerse himself in a VR or telepresence environment and look around within the environment while at the same time permitting other viewers concurrently to independently engage in the same activity on the same broadcast video signal. There has also been a need for a method and apparatus capable of providing such dewarping on a general purpose high speed computer.
SUMMARY OF THE INVENTION
The present invention overcomes the limitations of the prior art. In particular, the present invention transforms a plurality of viewing vectors within a selected portion of the wide angle, three dimensional video input into two dimensional control points and uses a comparatively simple method to transform the image between the control points to create a perspective-corrected field of view.
More specifically, the present invention is drawn to a method and apparatus which provides perspective corrected views of live, prerecorded or simulated wide angle environments. The present invention first captures a wide angle digital video input by any suitable means, such as through the combination of a high resolution video camera, hemispherical fisheye lens and real time digital image capture board. The captured image is then stored in a suitable memory means so portions of the image may be selected at a later time.
When a portion of the stored video is selected, a plurality of discrete viewing vectors in three dimensional space are chosen and transformed into a plurality of control points in a corresponding two dimensional plane. The area between the control points, which is still warped from the original wide angle image capture, is then transformed into a perspective corrected field of view through a biquadratic polynomial mapping technique. The perspective corrected field of view is then displayed on a suitable displaying apparatus, such as a monitor or head mounted display. The present invention further has the ability to sense an inputted selection, orientation and magnification of a new portion of the stored video for transformation.
In comparison with the prior art, the present invention provides a dependable, low cost, faster and more elegantly simple solution to dewarping wide angle three dimensional images. The present invention also allows for simultaneous dynamic transformation of wide angle video to multiple viewers and provides each user with the ability to access and manipulate the same or different portions of the video input. In VR applications, the present invention also allows the computer generated three dimensional polygons to be rendered in advance; thus, users may view the environments from any orientation quickly and without expensive rendering hardware.
It is therefore one object of the present invention to provide a method and apparatus for dewarping wide angle video to a perspective corrected field of view which can then be displayed.
It is another object of the present invention to provide a method and apparatus which can simultaneously transform the same or different portions of wide angle video input for different users.
It is yet another object of the present invention to provide a method and apparatus which allows selection and orientation of any portion of the video input.
It is still another object of the present invention to provide a method and apparatus for magnification of the video input.
It is still another object of the present invention to provide a method and apparatus which performs all of the foregoing objects while having no moving parts.
These and other objects of the invention will be better understood from the following Detailed Description of the Invention, taken together with the attached Figures.
THE FIGURES
FIG. 1 shows a functional block diagram of one embodiment of the present invention.
FIG. 2 diagrams the geometry between three dimensional (X-Y-Z) space and its corresponding two dimensional (U-V) plane.
FIG. 3a shows a bilinear mapping of a warped image.
FIG. 3b shows a biquadratic mapping of a warped image.
FIG. 4 shows a side view of a viewing vector from a three dimensional (X-Y-Z) wide angle lens as it is seen on a two dimensional (U-V) plane.
FIG. 5 shows a three dimensional field of view along with a plurality of viewing vectors according to the present invention.
FIG. 6 shows a block diagram of the elements of a forward texture mapping ASIC according to the present invention.
FIG. 7 shows an example of a U-V source texture transformed into a X-Y plane destination texture according to the present invention.
FIG. 8 is one embodiment of how to obtain a 360 degree view using six hemispherical fisheye lenses according to the present invention.
FIG. 9 is a functional flow chart of one embodiment of the present invention.
DETAILED DESCRIPTION OF THE INVENTION
Referring now to FIG. 1, an embodiment of the present invention for processing wide angle video information in real time is shown. A high resolution video camera 10 having a wide angle lens 20, such as a hemispherical fisheye lens, is directed to a real world scene 22. The output 24 of the camera 10 is provided to a real time image digitizing board 30, commonly referred to as a “frame grabber,” located in or operatively connected to a conventional high speed computer indicated generally at 150. The camera 10 may be any camera which is capable of using a wide angle lens and providing suitable resolution. In most instances the camera will be a video camera, although in some instances it may be desirable to use a still frame camera. One suitable fisheye lens is the Nikkor Auto 1:1.8 f=8 mm fisheye lens which can be adapted to a standard high resolution broadcast video camera with a Nikon FW-Eng TMW-B1 converter. The computer 150 is any computer capable of receiving and processing video information at an acceptable rate and may, for example, be an 80486-based or Pentium™-based system, or other computer platform such as are made by Silicon Graphics, Sun Micro Systems, Apple Computer, or similar other computer manufacturers.
The fisheye lens 20 causes the video output signal 24 from the camera 10 to be optically warped in a non-linear manner. Before the image can be comfortably viewed by a user, perspective-correcting measures must be taken. The digitized video signal 24 is thus transferred through the digitizing board 30 (typically but not necessarily operating at 30 frames per second) into memory 40 of the computer 150 so that portions of the video picture can be randomly accessed by a microprocessor 50, also within the computer 150, at any time.
The dewarping software is also stored in memory 40 and is applied to the video signal 24 by the microprocessor 50. The stored video signal is then transmitted from memory 40 to a special purpose ASIC 60 capable of biquadratic or higher order polynomial transformations for texture warping and interpolation. Alternatively, the texture warping ASIC 60 may be omitted and its functionality may be performed by software. Phantom lines have been used to show the optional nature of ASIC 60. The perspective corrected video signal is next transmitted to a video output stage 70, such as a standard VGA card, and from there displayed on a suitable monitor, head mounted display or the like 80. An input device 90, such as a joystick or headtracker (which senses the head movements of a user wearing a headmounted display), transmits position information through a suitable input port 100, such as a standard serial, parallel or game port, to the microprocessor 50 to control the portion of the stored video that is selected, dewarped and displayed. The input device 90 also transmits roll/pitch/yaw information to the microprocessor 50 so that a user may control the orientation of the dewarped video signal. Further, one skilled in the art will appreciate that a magnification option could be added to the input device 90 to allow the user to magnify the selected portion of video input, constrained only by the resolution of the camera 10.
FIG. 2 shows a real world three dimensional environment 200 which has been imaged by the wide angle lens 20. This environment is defined by the Cartesian coordinate system in X, Y and Z with the viewpoint defined to be the origin of the coordinate system. The viewing direction of the user, as defined by the input device 90, is given as a viewing vector in the X-Y-Z coordinate system. The image plane 210 containing the warped wide angle image is defined by a two dimensional coordinate system in U and V, with the origin of the coordinate system coincident with the origin of the X-Y-Z coordinate system. If the field of view of the lens 20 is sufficient, and the lens is rotationally symmetric about the viewing axis, the digitized warped image will be roughly circular in the U-V plane.
The first generation of ASICs, developed for low-cost texture mapping of three dimensional graphics, mapped video images through a bilinear technique, such as is shown in FIG. 3(a). These chips were able to apply linear interpolation to texture pixels in both the X and Y directions and could thereby stretch rectangular source textures to any two dimensional quadrilateral shape. An example of a chip of this type is the Artist Graphics 3GA chip. These bilinear chips do, however, introduce texture errors for polygons whose vertices have been subject to significant amounts of perspective, and further are not capable of sufficiently high order texture distortion to adequately flatten extreme wide angle views, such as with hemispherical fisheye lenses.
FIG. 3b shows an example of a biquadratic technique, such as is now coming onto the market. The preferred embodiment of the present invention uses an ASIC chip which implements a texture warping technique of at least second polynomial order. The present invention is of sufficient simplicity that this technique could also be implemented in software on a general purpose high speed computer, such as a Silicon Graphics Indigo™ computer or a Pentium™ based computer.
The warped image in the U-V plane, shown in FIG. 2, has a radius 220 equal to RADIUS pixels with an origin at UORIGIN and VORIGIN. For any rotationally symmetric lens, the warping effect of the lens can be described by a single lens equation, r=f(θ), where the function f(θ) maps any incident ray at angle θ from the axis of viewing to a radial displacement in pixels, r, from the center of the U-V plane, as shown in FIG. 4.
For any given viewing direction in three dimensional X-Y-Z space, we then have:
s = x 2 + y 2 ( 1 ) θ = arc tan s z r = f ( θ ) u = rx s v = ry s
In the case of an ideal hemispheric fisheye lens, f(θ)=(RADIUS)(sin(θ)) and the lens equation which results is:
r = ( RADIUS ) ( s ) z 1 + s 2 z 2 = ( RADIUS ) x 2 + y 2 z 1 + x 2 + y 2 z 2 ( 2 )
Equations (1) convert an inputted X-Y-Z three dimensional viewing vector into a corresponding control point in the U-V plane.
To dewarp a rectangular portion of the wide angle video input for a given viewing direction (x,y,z), eight other viewing vectors, which surround the primary viewing vector, are computed at the field of view angles fov_h and fov_v from the primary viewing vector, as shown in FIG. 5. Each of these nine vectors are then projected from three dimensional X-Y-Z space to the two dimensional U-V plane by equations (1). The result is a 3×3 grid of control points in the U-V plane, with the edges of the grid curving mathematically to conform with the curvature induced by the warping effect of the wide angle lens.
The global bivariate polynomial transformation
u = N i = 0 N - i j = 0 a ij x i y j ( 3 ) v = N i = 0 N - i j = 0 b ij x i y j with  x  and  y  now referring  to  the  pixel  coordinates in  the  output  device
is then found to describe the geometric correction necessary to transform the region within the warped 3×3 grid in the U-V plane into a perspective corrected field of view. A biquadratic polynomial transformation, N=2 in the above equations, has been selected because a second order polynomial approximates the warping characteristics of most lenses to an adequately high degree of precision and because there is existing hardware to perform the resulting biquadratic transformation. However, it will be appreciated by one skilled in the art that other polynomial transformations of higher degree could be used to increase the precision of the transformation.
Expanding the above equations (3):
[ u 1 u 2 u 3 u 4 u 5 u 6 u 7 u 8 u 9 ] = [ 1 x 1 y 1 x 1 y 1 x 1 2 y 1 2 1 x 2 y 2 x 2 y 2 x 2 2 y 2 2 1 x 3 y 3 x 3 y 3 x 3 2 y 3 2 1 x 4 y 4 x 4 y 4 x 4 2 y 4 2 1 x 5 y 5 x 5 y 5 x 5 2 y 5 2 1 x 6 y 6 x 6 y 6 x 6 2 y 6 2 1 x 7 y 7 x 7 y 7 x 7 2 y 7 2 1 x 8 y 8 x 8 y 8 x 8 2 y 8 2 1 x 9 y 9 x 9 y 9 x 9 2 y 9 2 ] [ a 00 a 10 a 01 a 11 a 20 a 02 ] ( 4 )
The values for v and bij can be similarly found. In matrix form, the expanded equations (4) can be written as:
U=WA
V=WB  (5)
To discover aij and bij according to the method of the present invention, a pseudo-inverse technique is used. However, one skilled in the art will appreciate that there are methods to solve equations (5) other than by a pseudo inverse technique, i.e. a least squares technique. The pseudo-inverse solutions for A and B in the above equation (5) are:
A=(WTW)−1WTU
B=(WTW)−1WTV  (6)
Therefore, for a target display Cot a given pixel resolution N×M, W and its pseudo-inverse (WTW)−1WT can be calculated a priori. The values for aij and bij are then found by mapping the points in the U-V plane for the 3×3 grid of control points using the above equations (6). The biquadratic polynomial transformations of the equations (3) are then used to transform the area between the control points. In this embodiment, the determination of the coordinates of each pixel in the U-V plane takes a total of thirteen multiplication and ten addition operations. Additionally, three of the required multiplication operations per pixel may be obviated by storing a table of xy, x2 and y2 values for each xy coordinate pair in the dewarped destination image. In another embodiment, the “x” values which do not vary as “y” changes (i.e. a1*x+a4*x2 and b1*x+b4*x2) may also be precomputed and stored. Likewise, the “y” values which do not vary as “x” changes may be precomputed and stored. These further optimizations reduce the operations needed to determine the coordinates of each pixel in the U-V plane to two multiplication and four addition operations.
It will be appreciated by one skilled in the art that the accuracy of the dewarping transformation will increase as the number of transformed viewing vectors increases, i.e. a 4×4 grid of control points will produce a more accurate transformation than a 3×3 grid of control points. However, the amount of increase in accuracy quickly draws near an asymptote as the number of control points is increased. One skilled in the art will recognize, therefore, that there is little reason in increasing the number of viewing vectors to more than half of the total number of pixels in the displayed region.
It will be further appreciated by one skilled in the art that the selection of a rectangular shape of the video input could be changed to another shape and still be within the scope of the invention. Further, the number of control points could be increased or decreased to correspondingly increase or decrease the accuracy of the transformation. Further still, an image filtering stage could be applied during the inverse texture mapping without deviating from the present invention.
FIG. 9 shows a functional flow chart of the major elements of one embodiment of the present invention. First, the fixed warped image parameters (step 400) are defined, such as the size of the input image, the input image radius, and the input image center in U-V coordinates typically measured in pixels. The next step 410 is to initialize the variable dewarped image parameters, such as the size of the dewarped image area, the horizontal and vertical field of views (generally shown in degrees), the creation of an untransformed view cone centered in this embodiment on the +Z axis and the initialization of the layout and number control points used therewith. Typically, the next step is to load the precomputed inner-loop matrix values as well as the “xy” product terms, as shown in step 420, to ensure that the transformation is accomplished as quickly and efficiently as possible. In step 430, the video signal is input to the system in any suitable form, i.e. live or pre-recorded real-time digitized video or computer synthesized video environments. The system then allows the user to select the viewing vector (step 440) which in turn determines the portion of video which is to be transformed. The control points are next transformed from the selected viewing vectors (step 450) and the region defined by the control points is dewarped (step 460). The signal is then sent to the video buffer and to an appropriate viewing apparatus (step 470). There is a recursive loop from step 470 to step 430 to allow the video signal to be refreshed, as is needed with live motion video. The loop also allows the user to make on-the-fly selections of alternate portions of the incoming video.
The foregoing description describes an inverse texture mapping technique whereby the biquadratic output (X-Y) is mapped to the input (U-V). In the case where a forward texture mapping ASIC is used, the coordinates for the destination control points in X-Y must be supplied so that the rectilinear source texture region can be mapped from the U-V plane, as provided by the inverse texture mapping software solution above, to the X-Y plane. An example of a forward texture mapping ASIC is the NV-1 chip sold by N-Vidia Corporation. FIG. 6 gives another example of an ASIC chip 230 which accepts control pixel coordinates at a forward mapping solution stage 240. Four pixel coordinates will be accepted for a bilinear mapping, nine in the case of quadratic mapping, 16 in the case of cubic mapping, etc. These control pixels are produced in the host CPU according to the equations (7), below. As shown in FIG. 7, the coordinates of a rectangular bounding box are determined to enclose an exemplary 3×3 grid of control points uivi in the U-V plane. The corners of the bounding box are found from the uivi extrema. Using the same technique described in equations (3), aij and bij for N=2 can be solved with the equations (7) for enclosing the region to be warped to the corners of the display screen.
x = N i = 0 N - i j = 0 a ij u i v j ( 7 ) y = N i = 0 N - i j = 0 b ij u i v j
Thus, the same control points for the U-V plane map to the corners of the display screen in the X-Y plane. The warped regions outside the bounding box may be clipped by hardware or software so that they are not visible on the display screen.
The source pixel coordinates, which are fed from the host CPU, are converted to aij and bij coordinates for forward mapping in the forward mapping solution stage 240, again using techniques mathematically equivalent to those of the equations (7). A series of instructions is further sent from the host CPU to the chip 230 and received by a control unit 260. The control unit 260 sequences and controls the operation of the other functional stages within the chip 230. The host CPU also directs a linear sequence of source pixels, which are to be warped, to an interpolation sampler stage 250 within chip 230. Optionally, these can be subject to a low-pass spatial prefiltering stage 270 prior to transmission to the chip, to reduce sampling error during the warping process. Thus, within the chip 230, the source pixels and the aij and bij coordinates are both fed to the interpolation sampler 250. For each input pixel, one or more destination pixels together with their corresponding X-Y destination coordinates are produced. These warped pixels are then fed into the video frame buffer 280, located outside of the ASIC chip 230. Optionally, anti-aliasing circuitry 290 within the chip performs interpolation on output pixel values, such as bilinear interpolation between adjacent pixel samples, to minimize the effects of output spatial quantization error. One skilled in the art will recognize that the preceding hardware solution is merely exemplary and that there are many such solutions which could be employed and still fall within the scope of the present invention.
The techniques described herein may also be applied to synthetic images. Such images may be created entirely within a computer environment and may be composed of three dimensional geometrical descriptions of objects which can be produced by computer graphics rendering techniques generally known to those skilled in the art. Typically, synthetic images are produced by linear perspective projection, emulating the physical process of imaging onto planar film with a lens having a narrow field of view and producing a view of the synthetic environment as seen through a cone or truncated three dimensional pyramid. The color, intensity shading and other simulated physical properties of each pixel on the planar image grid can also be readily determined. For a synthetic environment, the viewing vectors in X-Y-Z space are rewritten in terms of the warped control points coordinates in the U-V plane
r = u 2 + v 2 ( 8 ) s = r RADIUS x = us r y = vs r z = 1 - s 2
A direction vector in X-Y-Z space can thus be generated for each pixel in the U-V plane in the synthetic wide angle image which is created. For a perfect hemispherical fisheye, the generated vectors point in all directions within the created hemisphere, spaced to the limits of the resolution of the U-V image. This simulates a non-planar image grid, such as the projection of the synthetic environment onto a surface of a spherical image substrate. In this way, a fisheye or other wide angle image of a synthetic three dimensional environment can be produced. This technique can be used for the production of three dimensional modeled cartoons or interactive home gaming applications, among others.
One skilled in the art will appreciate that the present invention may be applied to a sequence of wide angle images changing in time, either live or recorded to an analog or digital storage media. The image substrate for recordation may be an electronic two dimensional image sensor, such as a CCD chip, or photographic film capable of chemically recording the image for subsequent transfer into digital form.
One skilled in the art will also appreciate that the present invention is not limited to transforming wide angle video onto a planar (U-V) surface, but that it is within the scope of the invention to transform wide angle video onto any suitable surface for displaying the video for the user.
Further, two real world, wide angle lenses can be positioned opposite each other to permit near 360 degrees of total coverage of the environment. If seamless omnidirectional coverage of an environment is required, this could be achieved with six wide angle lenses positioned along each direction of a three dimensional axis, as shown in FIG. 8. This arrangement can be coupled with a video switching mechanism for choosing which signal is to be dewarped for the selected view and orientation of the video input.
Further still, the same video signal may be simultaneously transmitted to an arbitrarily large number of viewers all having the ability to simultaneously dewarp the same or different portions of the video input, as in the case of interactive cable TV viewing or multiple player online interactive video game playing.
Having fully described the preferred embodiment of the present invention, it will be apparent to those of ordinary skill in the art that numerous alternatives and equivalents exist which do not depart from the invention set forth above. It is therefore to be understood that the present invention is not to be limited by the foregoing description, but only by the appended claims.

Claims (42)

1. A method for providing perspective corrected images from at least one distorted image, the method comprising steps of:
receiving said distorted image;
storing a portion of said distorted image;
transforming a set of control vectors to a set of control points that defines an area that associates said portion of said distorted image with a portion of a perspective corrected image;
transforming said portion of said distorted image associated with said area to said portion of said perspective corrected image using a global bivariate polynomial transformation;
displaying said portion of said perspective corrected image;
sensing inputted information; and
controlling the transformation and display of said perspective corrected image through said inputted information.
2. The method of claim 1 wherein the step of transforming said portion of said distorted image is accomplished using:
u = N i = 0 N - i j = 0 a ij x i y j v = N i = 0 N - i j = 0 b ij x i y j .
as said global bivariate polynomial transformation.
3. The method of claim 2 wherein N is 2 or 3.
4. The method of claim 1 wherein said set of control points contains a number of control points, said number having a lower limit of five and an upper limit of one-half of the number of pixels in said portion of said perspective corrected image.
5. The method of claim 1 wherein said distorted image is received from a computer storage device.
6. The method of claim 1 wherein said distorted image is received from a network.
7. The method of claim 6 wherein said network is a computer network.
8. The method of claim 6 wherein said network is in communication with the Internet.
9. The method of claim 1 wherein said distorted image is a result of imaging an environment through at least one wide-angle lens.
10. The method of claim 1 wherein said distorted image is a result of imaging an environment through at least one fisheye lens.
11. The method of claim 1 wherein said distorted image includes an image of at least one sixth of an environment.
12. An apparatus for providing perspective corrected images from at least one distorted image, the apparatus comprising:
an input configured to receive said distorted image;
a memory, coupled to the input, configured to store a portion of said distorted image;
a processor, coupled to the memory, configured to transform a set of control vectors to a set of control points that defines an area that associates said portion of said distorted image with a portion of a perspective corrected image, the processor further configured to transform said portion of said distorted image associated with said area to said portion of said perspective corrected image using a global bivariate polynomial transformation;
a presentation mechanism, coupled to the memory, configured to present said portion of said perspective corrected image; and
a selection mechanism, coupled to the processor, configured to specify said set of control vectors.
13. The apparatus of claim 12 wherein the transformation of said portion of said distorted image is accomplished using:
u = N i = 0 N - i j = 0 a ij x i y j v = N i = 0 N - i j = 0 b ij x i y j .
as said global bivariate polynomial transformation.
14. The method of claim 13 wherein N is 2 or 3.
15. The apparatus of claim 12 wherein said set of control points contains a number of control points, said number having a lower limit of five and an upper limit of one-half of the number of pixels in said portion of said perspective corrected image.
16. The apparatus of claim 12 wherein said distorted image is received from a computer storage device.
17. The apparatus of claim 12 wherein said distorted image is received from a network.
18. The apparatus of claim 17 wherein said network is a computer network.
19. The apparatus of claim 17 wherein said network is in communication with the Internet.
20. The apparatus of claim 12 wherein said distorted image is a result of imaging an environment through at least one wide-angle lens.
21. The apparatus of claim 12 wherein said distorted image is a result of imaging an environment through at least one fisheye lens.
22. The apparatus of claim 12 wherein said plurality of distorted images includes an image of at least one sixth of an environment.
23. A method of providing perspective corrected views of live, prerecorded or simulated environments from wide angle video signals, the method comprising:
receiving video input data at a computing device;
transforming, by the computing device, a plurality of viewing vectors defining a portion of the video input data to a plurality of control points;
transforming, by the computing device, pixel data in an area between the plurality of control points to define perspective corrected pixel data; and
sending the perspective corrected pixel data to a display for display of the perspective corrected pixel data.
24. The method of claim 23 further comprising determining the plurality of viewing vectors at the computing device based on position and orientation information of a device and a horizontal field of view and a vertical field of view.
25. The method of claim 23 further comprising receiving a selection of the plurality of viewing vectors at the computing device.
26. The method of claim 23 wherein the plurality of viewing vectors define an area of interest.
27. The method of claim 23 wherein a global bivariate polynomial transformation is used to define the perspective corrected pixel data.
28. The method of claim 27 wherein the global bivariate polynomial transformation is a biquadratic polynomial transformation.
29. A system comprising:
a computer-readable memory configured to store video input data; and
a processor operably coupled to the computer-readable memory to receive the stored video input data, the processor configured to perform operations comprising
transforming a plurality of viewing vectors defining a portion of the stored video input data to a plurality of control points;
transforming pixel data in an area between the plurality of control points to define perspective corrected pixel data; and
sending the perspective corrected pixel data to a display.
30. The system of claim 29, wherein the processor is an ASIC.
31. The system of claim 29, wherein the computer-readable memory has computer-executable instructions stored thereon execution of which by the processor causes the processor to perform the operations.
32. The system of claim 29, wherein the operations further comprise determining the plurality of viewing vectors based on position and orientation information of a device, a horizontal field of view, and a vertical field of view.
33. The system of claim 29, wherein the operations further comprise receiving a selection of the plurality of viewing vectors.
34. The system of claim 29, wherein the plurality of viewing vectors define an area of interest.
35. The system of claim 29, wherein a global bivariate polynomial transformation is used to define the perspective corrected pixel data.
36. The system of claim 35, wherein the global bivariate polynomial transformation is a biquadratic polynomial transformation.
37. A method of performing perspective correction, the method comprising:
transforming, by a computing device, a set of control vectors into a set of control points using a function that models a wide angle lens;
generating, by the computing device, a polynomial transform function that maps the control points into rectangular points;
transforming, by the computing device, an area of image data proximate the set of control points using the polynomial transform function; and
sending the transformed area of image data to a display for display of the transformed area of image data.
38. The method of claim 37, wherein the polynomial transformation function comprises a global bivariate polynomial.
39. The method of claim 37, wherein the polynomial transformation comprises a biquadratic polynomial.
40. The method of claim 37, wherein the set of control vectors comprise a principal viewing vector and eight surrounding vectors that form a rectangular view.
41. The method of claim 37, wherein the wide-angle lens comprises a fish eye lens.
42. A system comprising:
a computer-readable memory configured to store captured image data; and
a processor operably coupled to the computer-readable memory to receive the stored captured image data, the processor configured to perform operations comprising
transforming a set of control vectors into a set of control points using a function that models a wide angle lens;
generating a polynomial transform function that maps the control points into rectangular points;
transforming an area of the captured image data proximate the set of control points using the polynomial transform function; and
sending the transformed area of image data to a display.
US12/118,570 1994-05-27 2008-05-09 Wide-angle dewarping method and apparatus Expired - Fee Related USRE43490E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US12/118,570 USRE43490E1 (en) 1994-05-27 2008-05-09 Wide-angle dewarping method and apparatus

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US08/250,594 US5796426A (en) 1994-05-27 1994-05-27 Wide-angle image dewarping method and apparatus
US09/128,963 US6005611A (en) 1994-05-27 1998-08-04 Wide-angle image dewarping method and apparatus
US09/429,697 US6346967B1 (en) 1994-05-27 1999-10-28 Method apparatus and computer program products for performing perspective corrections to a distorted image
US10/015,075 US7042497B2 (en) 1994-05-27 2001-12-10 Wide-angle dewarping method and apparatus
US12/118,570 USRE43490E1 (en) 1994-05-27 2008-05-09 Wide-angle dewarping method and apparatus

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US10/015,075 Reissue US7042497B2 (en) 1994-05-27 2001-12-10 Wide-angle dewarping method and apparatus

Publications (1)

Publication Number Publication Date
USRE43490E1 true USRE43490E1 (en) 2012-06-26

Family

ID=26827117

Family Applications (1)

Application Number Title Priority Date Filing Date
US12/118,570 Expired - Fee Related USRE43490E1 (en) 1994-05-27 2008-05-09 Wide-angle dewarping method and apparatus

Country Status (1)

Country Link
US (1) USRE43490E1 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100033551A1 (en) * 2008-08-08 2010-02-11 Adobe Systems Incorporated Content-Aware Wide-Angle Images
US20140314336A1 (en) * 2011-12-19 2014-10-23 Dai Nippon Printing Co., Ltd. Image processing device, image processing method, program for image processing device, recording medium, and image display device
US20150160539A1 (en) * 2013-12-09 2015-06-11 Geo Semiconductor Inc. System and method for automated test-pattern-free projection calibration
WO2017075501A1 (en) * 2015-10-30 2017-05-04 Essential Products, Inc. An imaging device and method for generating an undistorted wide view image
US9813623B2 (en) 2015-10-30 2017-11-07 Essential Products, Inc. Wide field of view camera for integration with a mobile device
US9843725B2 (en) 2015-12-29 2017-12-12 VideoStitch Inc. Omnidirectional camera with multiple processors and/or multiple sensors connected to each processor
US9906721B2 (en) 2015-10-30 2018-02-27 Essential Products, Inc. Apparatus and method to record a 360 degree image
US10021301B2 (en) 2015-12-29 2018-07-10 VideoStitch Inc. Omnidirectional camera with multiple processors and/or multiple sensors connected to each processor
CN109618090A (en) * 2017-10-04 2019-04-12 英特尔公司 To the method and system of the image distortion correction by using wide-angle lens captured image
US20190116316A1 (en) * 2014-12-24 2019-04-18 Agamemnon Varonos Panoramic windshield viewer system
US10400929B2 (en) 2017-09-27 2019-09-03 Quick Fitting, Inc. Fitting device, arrangement and method
US10771774B1 (en) * 2019-03-22 2020-09-08 Varjo Technologies Oy Display apparatus and method of producing images having spatially-variable angular resolutions
US10969047B1 (en) 2020-01-29 2021-04-06 Quick Fitting Holding Company, Llc Electrical conduit fitting and assembly
US11035510B1 (en) 2020-01-31 2021-06-15 Quick Fitting Holding Company, Llc Electrical conduit fitting and assembly

Citations (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3953111A (en) 1974-11-04 1976-04-27 Mcdonnell Douglas Corporation Non-linear lens
US4728839A (en) 1987-02-24 1988-03-01 Remote Technology Corporation Motorized pan/tilt head for remote control
US4751660A (en) 1985-07-09 1988-06-14 Sony Corporation Determining orientation of transformed image
US4754269A (en) 1984-03-05 1988-06-28 Fanuc Ltd Graphic display method for displaying a perspective view of an object on a CRT
US4772942A (en) 1986-01-11 1988-09-20 Pilkington P.E. Limited Display system having wide field of view
GB2221118A (en) 1988-06-21 1990-01-24 Sony Corp Image transformation apparatus
US5023725A (en) 1989-10-23 1991-06-11 Mccutchen David Method and apparatus for dodecahedral imaging system
US5048102A (en) 1987-09-16 1991-09-10 Commissariat A L'energie Atomique Multiple interpolation process for image correction
US5067019A (en) 1989-03-31 1991-11-19 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Programmable remapper for image processing
WO1992021208A1 (en) 1991-05-13 1992-11-26 Telerobotics International, Inc. Omniview motionless camera orientation system
US5173948A (en) 1991-03-29 1992-12-22 The Grass Valley Group, Inc. Video image mapping system
US5175808A (en) 1989-09-12 1992-12-29 Pixar Method and apparatus for non-affine image warping
US5384588A (en) 1991-05-13 1995-01-24 Telerobotics International, Inc. System for omindirectional image viewing at a remote location without the transmission of control signals to select viewing parameters
US5422987A (en) 1991-08-20 1995-06-06 Fujitsu Limited Method and apparatus for changing the perspective view of a three-dimensional object image displayed on a display screen
US5796426A (en) 1994-05-27 1998-08-18 Warp, Ltd. Wide-angle image dewarping method and apparatus
EP0610863B1 (en) 1993-02-08 2001-11-14 Interactive Pictures Corporation Omniview motionless camera surveillance system
US7873233B2 (en) * 2006-10-17 2011-01-18 Seiko Epson Corporation Method and apparatus for rendering an image impinging upon a non-planar surface

Patent Citations (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3953111A (en) 1974-11-04 1976-04-27 Mcdonnell Douglas Corporation Non-linear lens
US4754269A (en) 1984-03-05 1988-06-28 Fanuc Ltd Graphic display method for displaying a perspective view of an object on a CRT
US4751660A (en) 1985-07-09 1988-06-14 Sony Corporation Determining orientation of transformed image
US4772942A (en) 1986-01-11 1988-09-20 Pilkington P.E. Limited Display system having wide field of view
US4728839A (en) 1987-02-24 1988-03-01 Remote Technology Corporation Motorized pan/tilt head for remote control
US5048102A (en) 1987-09-16 1991-09-10 Commissariat A L'energie Atomique Multiple interpolation process for image correction
GB2221118A (en) 1988-06-21 1990-01-24 Sony Corp Image transformation apparatus
US5067019A (en) 1989-03-31 1991-11-19 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Programmable remapper for image processing
US5175808A (en) 1989-09-12 1992-12-29 Pixar Method and apparatus for non-affine image warping
US5023725A (en) 1989-10-23 1991-06-11 Mccutchen David Method and apparatus for dodecahedral imaging system
US5173948A (en) 1991-03-29 1992-12-22 The Grass Valley Group, Inc. Video image mapping system
WO1992021208A1 (en) 1991-05-13 1992-11-26 Telerobotics International, Inc. Omniview motionless camera orientation system
US5185667A (en) 1991-05-13 1993-02-09 Telerobotics International, Inc. Omniview motionless camera orientation system
US5384588A (en) 1991-05-13 1995-01-24 Telerobotics International, Inc. System for omindirectional image viewing at a remote location without the transmission of control signals to select viewing parameters
US5877801A (en) 1991-05-13 1999-03-02 Interactive Pictures Corporation System for omnidirectional image viewing at a remote location without the transmission of control signals to select viewing parameters
US5422987A (en) 1991-08-20 1995-06-06 Fujitsu Limited Method and apparatus for changing the perspective view of a three-dimensional object image displayed on a display screen
EP0610863B1 (en) 1993-02-08 2001-11-14 Interactive Pictures Corporation Omniview motionless camera surveillance system
US5796426A (en) 1994-05-27 1998-08-18 Warp, Ltd. Wide-angle image dewarping method and apparatus
US6005611A (en) 1994-05-27 1999-12-21 Be Here Corporation Wide-angle image dewarping method and apparatus
US6346967B1 (en) 1994-05-27 2002-02-12 Be Here Corporation Method apparatus and computer program products for performing perspective corrections to a distorted image
US7873233B2 (en) * 2006-10-17 2011-01-18 Seiko Epson Corporation Method and apparatus for rendering an image impinging upon a non-planar surface

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
Rebiai et al. "Image Distortion from Zoom Lenses: modeling and digital correction," IBC 1992, pp. 438-441, IEE London, UK, Jul. 1992.
Rebiai et al., "Image Distortion from Zoom Lenses: modeling and digital correction," IBC 1992, pp. 438-441, IEE London, UK, Jul. 1992.

Cited By (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100033551A1 (en) * 2008-08-08 2010-02-11 Adobe Systems Incorporated Content-Aware Wide-Angle Images
US8525871B2 (en) * 2008-08-08 2013-09-03 Adobe Systems Incorporated Content-aware wide-angle images
US9742994B2 (en) 2008-08-08 2017-08-22 Adobe Systems Incorporated Content-aware wide-angle images
US20140314336A1 (en) * 2011-12-19 2014-10-23 Dai Nippon Printing Co., Ltd. Image processing device, image processing method, program for image processing device, recording medium, and image display device
US9269124B2 (en) * 2011-12-19 2016-02-23 Dai Nippon Printing Co., Ltd. Image processing device, image processing method, program for image processing device, recording medium, and image display device
US20150160539A1 (en) * 2013-12-09 2015-06-11 Geo Semiconductor Inc. System and method for automated test-pattern-free projection calibration
US10901309B2 (en) * 2013-12-09 2021-01-26 Geo Semiconductor Inc. System and method for automated test-pattern-free projection calibration
US20180196336A1 (en) * 2013-12-09 2018-07-12 Geo Semiconductor Inc. System and method for automated test-pattern-free projection calibration
US9915857B2 (en) * 2013-12-09 2018-03-13 Geo Semiconductor Inc. System and method for automated test-pattern-free projection calibration
US20190116316A1 (en) * 2014-12-24 2019-04-18 Agamemnon Varonos Panoramic windshield viewer system
US9906721B2 (en) 2015-10-30 2018-02-27 Essential Products, Inc. Apparatus and method to record a 360 degree image
US9819865B2 (en) 2015-10-30 2017-11-14 Essential Products, Inc. Imaging device and method for generating an undistorted wide view image
US10218904B2 (en) 2015-10-30 2019-02-26 Essential Products, Inc. Wide field of view camera for integration with a mobile device
US9813623B2 (en) 2015-10-30 2017-11-07 Essential Products, Inc. Wide field of view camera for integration with a mobile device
WO2017075501A1 (en) * 2015-10-30 2017-05-04 Essential Products, Inc. An imaging device and method for generating an undistorted wide view image
US9843725B2 (en) 2015-12-29 2017-12-12 VideoStitch Inc. Omnidirectional camera with multiple processors and/or multiple sensors connected to each processor
US10021301B2 (en) 2015-12-29 2018-07-10 VideoStitch Inc. Omnidirectional camera with multiple processors and/or multiple sensors connected to each processor
US10400929B2 (en) 2017-09-27 2019-09-03 Quick Fitting, Inc. Fitting device, arrangement and method
CN109618090A (en) * 2017-10-04 2019-04-12 英特尔公司 To the method and system of the image distortion correction by using wide-angle lens captured image
US10771774B1 (en) * 2019-03-22 2020-09-08 Varjo Technologies Oy Display apparatus and method of producing images having spatially-variable angular resolutions
US10969047B1 (en) 2020-01-29 2021-04-06 Quick Fitting Holding Company, Llc Electrical conduit fitting and assembly
US11035510B1 (en) 2020-01-31 2021-06-15 Quick Fitting Holding Company, Llc Electrical conduit fitting and assembly

Similar Documents

Publication Publication Date Title
US7042497B2 (en) Wide-angle dewarping method and apparatus
USRE43490E1 (en) Wide-angle dewarping method and apparatus
US6870532B2 (en) Image display
US7426317B2 (en) Image processing apparatus and image processing method, storage medium and computer program
US5963215A (en) Three-dimensional browsing of multiple video sources
US6757446B1 (en) System and process for image-based relativistic rendering
EP0998727B1 (en) Texture mapping in 3-d computer graphics
US6243099B1 (en) Method for interactive viewing full-surround image data and apparatus therefor
CA2995665C (en) Image generating apparatus and image display control apparatus for a panoramic image
CN110648274B (en) Method and device for generating fisheye image
CN109997167B (en) Directional image stitching for spherical image content
JP6310898B2 (en) Image processing apparatus, information processing apparatus, and image processing method
Nielsen Surround video: a multihead camera approach
US20100033480A1 (en) Method for Interactively Viewing Full-Surround Image Data and Apparatus Therefor
JP3352475B2 (en) Image display device
CA2396575A1 (en) Curved image conversion method and record medium where this method for converting curved image is recorded
WO2009068942A1 (en) Method and system for processing of images
CN110675482A (en) Spherical Fibonacci pixel dot matrix panoramic picture rendering and displaying method for virtual three-dimensional scene
US11120606B1 (en) Systems and methods for image texture uniformization for multiview object capture
JPH07210705A (en) Virtual reality device
Nielsen High resolution full spherical videos
Byun et al. Air: Anywhere immersive reality with user-perspective projection
CN117931120B (en) Camera image visual angle adjusting method based on GPU
Der et al. Interactive viewing of panoramic images
Ott et al. Simulating a virtual fisheye lens for the production of full-dome animations

Legal Events

Date Code Title Description
AS Assignment

Owner name: B.H. IMAGE CO. LLC, DELAWARE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:BE HERE CORPORATION;REEL/FRAME:023535/0040

Effective date: 20071117

CC Certificate of correction
FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: CHARTOLEAUX KG LIMITED LIABILITY COMPANY, DELAWARE

Free format text: MERGER;ASSIGNOR:B.H. IMAGE CO. LLC;REEL/FRAME:037096/0897

Effective date: 20150812

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.)

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.)