Smooth Panorama Stitching With Lie Algebras
Mikola Lysenko
For this project, we were required to implement a panorama stitching program, with the option of creating a fully automatic image stitcher. Rather than follow the easier path of a cylindrical stitcher, I decided to take the road less travelled and try for a full AutoStitch workalike. In retrospect, this was perhaps too much as I have done very little these last few days except hack on this project. My health has suffered gravely and I am now a zombie like shell of my former self. However, despite missing the deadline by a few dozen hours, this project has been at least partially successful in meeting this ambitious goal.
The algorithm developed in this report solves the autostitching problem using a novel image warping algorithm. It automatically stitches arbitrary collections of images into low distortion panoramas regardless of camera configuration or scene geometry. This approach also works for cylindrical, spherical and many more types of panoramic images - even beyond those which are possible in AutoStitch. The key to making this system work is a clever application of the exponential map derived from the theory of Lie algebras which makes it possible to smoothly interpolate homographies.
Due to the time limitations of this class project, it was not possible to perform a thorough survey of related work, so instead the focus of this report is solely on the description of the technique. The outline of this document is as follows: first, the overall structure of the algorithm is summarized, followed by a description of the specific details. After this, potential improvements are discussed along with some conclusions about the basic approach. Finally, technical details about the accompanying software along with installation and usage instructions are elaborated.
The algorithm consists of 4 distinct phases. The first phase performs pairwise image alignment. This is done using the standard SIFT/RANSAC technique pioneered by Brown and Lowe. This result is then used to compute an initial layout of the images on the viewing plane based. Finally, the images are warped using the new Lie algebra interpolation and then blended.
Here is a brief summary of the pairwise alignment algorithm discussed in class: Given two images, , we want to compute a homography, , mapping to . To do this, we run SIFT on the pair of images to obtain a sequence of matching features,
, where are the coordinates of the feature in and
are the coordinates of its matching feature in . From this we randomly sample 4 matchings within the feature and attempt to fit a homography using the least-squares solution of the following system:
|
|
0 |
(1) |
Where:
From this, we count the number of inliers of and store this score in a table of weights, . The homography with the maximum score is taken to be .
After computing pairwise image alignment, we next compute a set of euclidean transformations, , from each image to the viewing plane. For the purposes of this project, we decided to place images relative to each other according to a maximum spanning tree with edge weights determined by (as computed in the alignment phase.) From this tree, we assign to the root of the tree the transformation and construct the remaining transformations by concatenating Euclidean approximations of the homographies. If is a directed edge in the tree, then define the transformation as follows:
Where is an operator which projects homographies onto the nearest Euclidean approximation. Several different estimates for were attempted during the course of this work. In the end, we resorted to using some problem specific knowledge. Because our final image is going to be a row of images, we simply project the homographies onto a single axis and store only translational components. This restriction may be relaxed to create arbitrary types of panoramas, such as those produced by AutoStitch. Finally, the arrangement of the scene tiles could be enhanced by taking into account user specific criteria or other aesthetic considerations.
In this section, a Lie algebra based image warping method is summarized. For such a simple procedure, deriving and debugging it took a substantial amount of time and is largely the reason for this homework being late. It is hoped that the grader shall be merciful and understanding in this account. We begin with a high level summary of the relevant aspects of Lie groups:
A Lie group is a group which is also differentiable manifold. This property endows it with a nice local structure: specifically around every element in the group, there exists a projection onto a Lie algebra which linearizes the group operator. This fact has many useful consequences. For example, spherical interpolation of quaternions is an instance of this type of mapping and is incredibly useful for skinning, camera tweening, character animation and much more.
The mapping from a Lie algebra around the identity to its corresponding Lie group is given by:
Where is an element of the Lie algebra, and is the identity. For matrices, mapping an element, , in the Lie group to the Lie algebra about the identity is given by:
These operators are respectively known as the exponential and logarithmic maps, as they generalize the same operators from real and complex numbers to higher dimensions. To find the Lie algebra about an element other than the identity, one may use the following identities:
It is important to note that the Lie algebra only approximates the group at a point. In general, the formula
will only hold if the group is commutative. This is the case for both the real and complex numbers, but certainly not for 3D rotations (aka ). The degree of commutativity between two elements, , can be measured using the Lie bracket operator, which is defined as:
Where are two elements of the Lie group. In a non-commutative Lie group, the bracket operator grows larger as get farther away from each other. Intuitively, the bigger the bracket gets, the worse the Lie algebra approximates the group operator. As a consequence, we can consider the Lie algebra approximation to be good when two elements are nearby and bad when two elements are far away.
Because the Lie algebra is linear, it gives us a nice way to interpolate elements of the Lie group. Suppose we are given an element, , which we wish to divide into evenly spaced intervals; in other words we wish to solve for in this equation:
If is suitably close to the identity, we can use the Lie algebra approximation to do the following trick:
Thus, applying -times is roughly the same as applying once. In the next section, we apply this idea to solving for smooth interpolations of camera motions.
The set of homographies (ie linear automorphisms of projective plane, ) is represented by the set of invertible 3x3 matrices modulo a scaling factor, in other words
. This object is a Lie group under the usual matrix multiplication operator. As a result, there is a natural way to interpolate between nearby homographies using the Lie algebra as described above. Given an image and its corresponding placement , we wish compute an interpolated warp,
, from the viewing plane into the coordinates of image . This done using a weighted sum of the transformation from the plane to some image back to the image at each point in space within the Lie algebra at . The weights for this are represented using some function
which gives:
The only restriction on the choice of is that for adjacent images the coordinates are compatible. Currently, we phrase this condition as follows:
To satisify this constraint, we construct a Delaunay triangulation of the centers of the images within a plane. Then, becomes the barycentric coordinate of the triangle containing , or 0 if the edge is not part of the site containing . In practice, this weighting produces plausible results, but it should be possible to define much better functions with more careful analysis.
At the moment, we have used a rather simplistic blending algorithm. From the interpolation phase, we store the weight associated with the identity transform in each pixel, then use this as the alpha term to blend the image into the map. With pre-multiplied alpha, the final compositing can be handled using a single post-processing phase. Better blending algorithms such as Laplacian smoothing or graph-cuts should produce higher quality images.
Figure 1:
Different types of panorama interpolation.
Euclidean warped panorama.
Perspective warped panorama.
Matrix interpolated warping about identity element.
Matrix interpolation about local Euclidean transform.
Correct Lie algebra based interpolation.
|
In this section, we examine the results of our new Lie algebra based interpolation scheme. Fig. 1 shows a comparison between perspective warping, non-interpolated Euclidean transforms, naive matrix interpolation and our new Lie algebra. The Euclidean transformation image shows the result of simply blending the images as placed by the arrangement phase of our algorithm. Overall, this does not produce a particularly smooth image. Perspective warping results in continuous images, but has bad distortion artifacts around the edges. Matrix interpolation is somewhat better, especially if the origin of the interpolation space is continuously moved. However, the Lie algebra method presented in this work has the fewest ghosting artifcats by far.
Figure 2:
Some examples of non-cylindrical panoramas.
|
Lie algebra based warping also makes it possible to stitch panoramas from non-cylindrical camera configurations. Some examples of this are shown in Fig. 2. In each of these cases, the camera was held free hand and no knowledge of the camera parameters was used. Of course, the algorithm is not perfect. Images with large amounts of parallax or few features will give incorrect results. This can be seen to some extent in the tree image as the branches and background are slightly ghosted. However, if a good homography exists between two images, then it should be possible to warp them using this algorithm.
In conclusion, it is true that I was more than a day late in finishing this project. However, in spite of this fact (or perhaps because of) I did develop a new type image warping with several novel properties. As a result, I believe that this work could be considered reasonably successful for a classroom project. Nonetheless, many obvious improvements remain.
First, the image placement phase of our algorithm is basically a hack. It is probably possible to formulate the problem of euclidean projection rigorously and derive optimal placement. Likewise, the weighting functions used in warping are somewhat ad-hoc and could probably be improved with more careful analysis. Also a better blending technique such as graph-cuts or Laplacian smoothing should eliminate the vignetting artificats seen in the results and would greatly increase the visual appeal of our results.
Finally, it is not clear that the Lie algebra based interpolation is always necessary. For relatively small homographies, the errors from linear interpolation are not too bad and could be hidden outright with a decent blending algorithm. As a result, it is not clear that in many situations the Lie algebra based approach is necessary, even though strictly speaking it will always produce more accurate results. However, the cost of Lie algebra interpolation vs. matrix methods is not terribly high for an offline process and the improvement in image quality is likely worth the trade off. Plus, adding this method to an additional image stitching software package has few drawbacks as the implementation overhead (in lines of code) is very low (once you work out the math).
This was my first experience working in MATLAB. As a result, some of the stylistic choices are probably a bit unusual. Nonetheless, the code mostly works and should be usable for creating simple panoramas. As a bonus feature, MATLAB has a pretty good implementation of the matrix logarithm/exponent, which makes interpolation much simpler. Also, the voronoi cell computation in the current version is a total hack and doesn't really work for a general stitcher. Fixing this should be easy (in theory), but it is outside the scope of this project.
To install the program you must download David Lowe's SIFT bindings for MATLAB. They are available here: . Once this is done, you need to add the code to your MATLAB path, which may be accomplished by typing in the MATLAB command prompt: path(path, 'path-to-SIFT-here');. After you have finished, extract all of the source code for this project into a single directory and navigate into it.
To use the sofware do the following:
- Place all of your pictures in a directory single directory, eg. "mypanorama". Make sure there are no other files in this directory.
- At the MATLAB command prompt, type pano_test('mypanorama'); to construct a panorama image from your data.
- Wait.
- Your panorama will be displayed on the screen and also saved to the file called "mypanorama.jpg".