Fast and Accurate Polar Fourier Transform: A. Averbuch, R.R. Coifman, D.L. Donoho, M. Elad, M. Israeli
Fast and Accurate Polar Fourier Transform: A. Averbuch, R.R. Coifman, D.L. Donoho, M. Elad, M. Israeli
Fast and Accurate Polar Fourier Transform: A. Averbuch, R.R. Coifman, D.L. Donoho, M. Elad, M. Israeli
21 (2006) 145167
www.elsevier.com/locate/acha
Abstract
In a wide range of applied problems of 2D and 3D imaging a continuous formulation of the problem places great emphasis on
obtaining and manipulating the Fourier transform in Polar coordinates. However, the translation of continuum ideas into practical
work with data sampled on a Cartesian grid is problematic. In this article we develop a fast high accuracy Polar FFT. For a given
two-dimensional signal of size N N , the proposed algorithms complexity is O(N 2 log N ), just like in a Cartesian 2D-FFT.
A special feature of our approach is that it involves only 1D equispaced FFTs and 1D interpolations. A central tool in our method
is the pseudo-Polar FFT, an FFT where the evaluation frequencies lie in an oversampled set of nonangularly equispaced points. We
describe the concept of pseudo-Polar domain, including fast forward and inverse transforms. For those interested primarily in Polar
FFTs, the pseudo-Polar FFT plays the role of a halfway pointa nearly-Polar system from which conversion to Polar coordinates
uses processes relying purely on 1D FFTs and interpolation operations. We describe the conversion process, and give an error
analysis of it. We compare accuracy results obtained by a Cartesian-based unequally-sampled FFT method to ours, both algorithms
using a small-support interpolation and no pre-compensating, and show marked advantage to the use of the pseudo-Polar initial
grid.
2005 Elsevier Inc. All rights reserved.
Keywords: Polar coordinates; Cartesian coordinates; Pseudo-Polar coordinates; Fast Fourier transform; Unequally-sampled FFT; Interpolation;
Linogram
1. Introduction
1.1. Polar Fourier transform
Fourier analysis is a fundamental tool in mathematics and mathematical physics, and also in signal and image
processing. The discovery, popularization, and digital realization of fast algorithms for Fourier analysisso called
FFThas had far reaching implications in science and technology in recent decades. The scientific computing com* Corresponding author.
146
munity regards the FFT as one of the leading algorithmic achievements of the 20th century [1]. In fact, even ordinary
consumer-level applications now involve FFTsthink of web browser decoding JPEG imagesso that development
of new tools for Fourier analysis of digital data may be of potentially major significance. In this paper we develop
tools associated with Fourier analysis in which the set of frequencies is equispaced when viewed in Polar coordinates.
Let f (x) = f (x1 , x2 ) be a function on the plane x = (x1 , x2 ) R2 . Let
f() = f (x) exp(i x) dx
be the usual continuum Fourier transform of f . Writing the frequency = {r cos( ), r sin( )} in Polar coordinates,
we let
f(r, ) = f (r, ) .
In this paper, the term Polar Fourier transform will always refer to the operation
f(r, ) = PF f (x) ,
namely, getting f (x) in Cartesian variables and computing f(r, ) defined with Polar variables.
While changes of variables are, of course, banal per se, their significance lies in the change of viewpoint they
provide. As it turns out, several fundamental procedures for manipulation of such continuum functions f can best be
defined in terms of Polar variables. The Polar FT can be a powerful tool for organizing our understanding of operators
and functions on the two-dimensional continuum. Much the same can be said of higher dimensions.
1.2. Digital problematics
The relatively simple and obvious continuum concepts, posing little or no intellectual challenge, correspond to
concrete processes operating on sampled digital data, which are important and widely used. Such is the case in image
rotation, image registration, tomography, and more. It seems natural to ask if the conceptual simplicity and clarity
of the continuum Polar FT can be used in some way to assist, improve, or simplify practical procedures for digital
processing, which appear as digitally sampled realizations of rotation, registration, radon transformation, and so on.
This leads naturally to the question of whether there could be a Polar FT for discrete data, particularly a fast
algorithm, or Polar FFT. Such a hypothetical entity should have many of the properties of the continuum Polar FT,
including relations to rotation, registration, Radon transform, and so on, and yet would be definable and rapidly
computed for digital data in the now ubiquitous equispaced Cartesian format.
The prevailing belief seems to be that there is no such algorithm. For example, in Briggs treatise The FFT: An
Owners Manual for the Discrete Fourier Transform [2], which is widely considered comprehensive and authoritative,
the index contains the entry Polar FFT, continuing with no FFT for, 284! Indeed, several difficulties stand in
our way to construct such a fast Polar FT for discrete data: (i) the need to define the appropriate Polar grid in the
frequency domain; (ii) finding a fast way to evaluate (or approximate) the FT on this grid points; and (iii) enabling a
stable transform inversion.
1.3. This papers contribution
In this paper we propose a notion of a Polar FT which is well suited for digital dataa procedure which is faithful
to the continuum Polar FT concept, highly accurate,1 fast, and generally applicable. As in Fig. 1, we define the Polar
grid of frequencies p,q = {x [p, q], y [p, q]} in the circle inscribed in the fundamental region [, )2 , and,
given digital Cartesian data f [i1 , i2 ] we define the Polar FT to be the collection of samples {F (p,q )}, where F (p,q )
is the trigonometric polynomial
F (p,q ) =
N
1 N
1
f [i1 , i2 ] exp i i1 x [p, q] i2 y [p, q] .
i1 =0 i2 =0
1 This implies that the proposed algorithm gives an approximated evaluation of the transform with high accuracy.
(1)
147
(2)
Thinking of the Polar Discrete Fourier Transform (PDFT) mapping PDFT : f [i1 , i2 ] F (p,q ) as a linear operator,
we also consider a generalized inverse procedure of it, going back from discrete Polar Fourier data to Cartesian spatial
data.
In this paper we carefully define the Polar FT concept for digital data, the associated fast algorithms, and discuss
its features such as accuracy and computational complexity. We will make special effort to describe five advantages of
the proposed PFFT, speed, accuracy, stability, vectorizability, and nonexpansivity. These terms will be given meaning
as we deepen our description. A brief and partial version of this work appeared in [3], and here we give an expanded
and more detailed description.
1.4. Relation to state of the art
Two existing bodies of literature contain ideas relevant to the above definition of Polar FTone corresponds to
methods to compute the inverse Radon transform, and the other treating the general problem of evaluating the Fourier
transform on nonequally spaced frequency points.
The literature of tomography concerns reconstruction of an image from a collection of its one-dimensional integrals. An important approach to this problem is the direct Fourier method [416]. The direct Fourier method uses
the projection-slice theorem, which suggests that one can convert a collection of projection data (Rf )(, ) into a
two-dimensional Fourier data f( ) on a Polar grid, and then reconstruct by Fourier inversion.
In the second body of literature [1729] one has data at an equally spaced Cartesian grid, but wishes to evaluate its
discrete Fourier transform as a nonequispaced non-Cartesian set of frequencies. This problem is known as either the
USFFT (short for Unequally Spaced FFT), or the NUFFT (non-Uniform FFT) problem.
It is not hard to see the direct relevance of the above literature to the definition we have given. The Polar sampling
set defined above is certainly a nonequispaced, non-Cartesian set. Thus, the problem of computing F (p,q ) from
digital data f [i1 , i2 ] is explicitly a problem of evaluating the Fourier transform of f at unequally spaced frequencies.
In other words, the problem of computing the PDFT is a special case of the USFFT problem. Second, note that, if we
take the projection data (Rf )(, ) and perform a discrete Fourier transform in the (discretely sampled) t-variable, we
148
Fig. 2. The pseudo-Polar grid and its separation into BV (filled circles) and BH (empty circles) coordinates (N = 8)intersection of 8 concentric
squares and 16 slope-equispaced rays.
effectively have f(p,q ). Hence, the problem of Radon inversion is closely connected to the problem of going back
from discrete Polar Fourier data f(p,q ) to Cartesian spatial data f [i1 , i2 ].
The existing state-of-the-art expressed by the above literature can be adapted to produce an approximated Polar
FFT (PFFT) and its inverse. Adapting ideas from the USFFT literature, the forward Polar-FFT can be accomplished
by the following stages: (i) pre-multiplication of f [i1 , i2 ] by pre-computed weights s[i1 , i2 ]; (ii) computation of the
2D-FFT on an oversampled Cartesian grid; and (iii) interpolation of the desired values on the Polar grid based on
those given on the Cartesian one. Reversing these operations can provide the adjoint operator. The inversion of the
transform can be accomplished, for example, by least-squares fitting, as proposed in [28]. This approach is similar to
ideas available in the direct Fourier reconstruction literature mentioned above.
The approach we propose here for PFFT is in fact similar to the above, using a special type of USFFT method,
where a different launching grid is used, rather than the Cartesian one. Our method factors the problem into two steps:
first, a pseudo-Polar FFT is applied, in which a pseudo-Polar sampling set is used, and second, a conversion from
pseudo-Polar to Polar FT is performed.
At the heart of the method proposed here for the PFFT we use the pseudo-Polar FFTan FFT where the evaluation
frequencies lie in an oversampled set of nonangularly equispaced points (see Fig. 2). The pseudo-Polar FFT offers us
a near-Polar frequency coordinate system for which exact rapid FT evaluation is possible [30]. Whereas the Polar grid
points sit at the intersection between linearly growing concentric circles and angularly equispaced rays, the pseudoPolar points sit at the intersection between linearly growing concentric squares and a specific choice of angularly
nonequispaced rays.
The pseudo-Polar transform plays the role of a halfway pointa nearly-Polar system from which conversion to
Polar coordinates uses processes relying purely on 1D FFTs and interpolation operations. We present this conversion process, along with an error analysis of it, showing far improved performance compared to the Cartesian-based
USFFT-based alternative approach. The reason for the expected improvement in accuracy is the ability of the pseudoPolar grid to provide a space-varying sampling of the frequency domain, which is close in density to the Polar
destination one. More specifically, the pseudo-Polar grid gives a denser sampling near the origin, enabling better
interpolation performance. In comparison, starting with a Cartesian grid, getting similar density (and thus accuracy)
near the origin requires an increased oversampling all-over the frequency domain. Note also that for most signals,
their energy resides near the origin, and thus, better treatment there implies higher overall accuracy.
149
As mentioned before, the above described approach enjoys the following important advantages:
Complexity. For a given two-dimensional signal of size N N , the complexity of both the proposed Polar FFT
and its inverse is of order N 2 log N , just like in a Cartesian 2D-FFT operating on the same input array.
Accuracy. Since polynomial interpolations are involved in the algorithms path, exact results cannot be claimed.
However, as will be shown later, the applied interpolations are expected to yield highly accurate results due to
specific features of the frequency domain function slices. The accuracy obtained is substantially better than the one
expected with Cartesian-based USFFT methods. We should note that this claim is demonstrated in our work for
short-support interpolation schemes that provide an overall simple algorithm. Recent work by Fessler and Sutton
[28] have clearly shown a marked improvement in the obtained accuracy with Cartesian USFFT when using large
support KaiserBessel interpolation and pre-compensation. Further work is required to use those options with
initial pseudo-Polar grid and explore ways to further improve our method.
Stability. This property refers mostly to our ability to invert the transform, and claim almost one-to-one mapping
between spatial array and its inverse PFFT result. Two ingredients are responsible for such a behavioradequate
conditioning of the signal, prior to its transform, and a proper set of Polar frequency samples that would be
considered representative.
Vectorizability. The process we propose is organized as a series of purely one-dimensional signal manipulation
processes, in which data form a single row or column of an array are subjected to a series of Fourier transforms,
1D interpolations, and ancillary operations. Owing to the use of vectorized operations, the overall algorithm is
cache-friendly.2
Nonexpansivity. There is no drastic oversampling of the underlying array. As we show later on, a similar accuracy
by a Cartesian-based USFFT method requires much higher oversampling.
1.5. Content
This paper is organized as follows: Section 2 describes the pseudo-Polar Fourier grid, and the forward/inverse
transforms over this grid. In this section we closely follow the work in [30]. Section 3 then discusses the conversion
from pseudo-Polar-to-Polar for the forward transform, and from Polar-to-pseudo-Polar in the inverse one. We show
how these conversions amount to one-dimensional operations and discuss reasons for the high interpolation accuracy
obtained. Section 4 analyzes the proposed algorithm from several aspects. Accuracy is studied by experimenting
on images, and by finding the worst-case scenarios maximizing the approximation error. Section 5 gives a brief
description of a freely available software performing the proposed PFFT transform. This software also includes the
code to reproduce this papers results. Section 6 concludes this paper, with discussion on future work and open
questions.
2. Pseudo-Polar Fourier transform
The pseudo-Polar Fourier transform is based on a definition of a Polar-like 2D grid that enables fast Fourier
computation. This grid has been explored by many since the 1970s. The pioneers in this field are Mersereau and
Oppenheim [31] who proposed the concentric squares grid as an alternative to the Polar grid. Work by Pasciak [32],
Edholm and Herman [33], and Lawton [34] showed that fast exact evaluation on such grids is possible. Later work
by Munson et al. [8,10] have shown how these ideas can be extended and used for tomography. Recently, the pseudoPolar grid was proposed as the base for a stable forward and inverse Radon transform called Fast Slant-Stack [30,35].
It has also been used for image registration [36].
As we shall see next, in this work we strongly build on this notion of near-Polar grid, and exploit the fast and stable
forward and inverse transforms with the frequency domain sampled with such coordinate system. In this section we
cover the basics of the pseudo-Polar grid and its use for forward and inverse transform.
2 We should note that Cartesian-based USFFT methods may also be made cache-efficient in various ways [25]. However, this property is far more
natural when the data is structured as in the pseudo-Polar coordinates.
150
Before we start we remind the reader of the Cartesian grid 2D DFT to set notations. Letting the horizontal and
vertical frequencies
2k1
2k2 N 1
,
, y =
x =
N
N k1 ,k2 =0
we get the familiar DFT in 2 dimensions by
f(x , y ) =
N
1 N
1
f [i1 , i2 ] exp i(i1 x + i2 y ) .
(3)
i1 =0 i2 =0
N
N
2m
for N < N,
x = y
for m <
(4)
BV = y =
N
N
2
2
and
BH = x =
N
for N < N,
y = x
2m
N
for
N
N
<m
.
2
2
(5)
Figure 2 depicts this grid; BV points are marked with the filled disks and BH ones are marked as circles. Several
properties about this grid should be mentioned:
The grid points are at intersections of linearly growing concentric squares with angularly nonequispaced rays.
The squares sides are of size k/N , k = 0, 1, . . . , N . The BH rays have equispaced slope: 2k/N , k = N/2 +
1, N/2 + 2, . . . , N/2. The BV rays are similar but with clockwise rotation of 90 .
The suggested grid is Polar-like. The main two differences are the concentric squares replacing concentric circles,
and equispaced rays in slope replaced by equispaced rays in angle. This resemblance will be exploited for the
development of a true Polar-FFT algorithm.
Referring to the BV (and similarly to the BH) points, we can see that they are organized on lines with angles
ranging from to . Along each such line, the points are spread uniformly, though in an angle-dependent way.
These two properties are the driving force for the ability to compute the Fourier transform in a fast way for this
grid.
When looking at Fig. 2 one might get the impression that some points on the outer-most square are missing.
However, since f(x , y ) is periodic with a period of 2 in both axes, these points are actually redundant.
In computing and storing the Fourier transform for these points, our data structure is given by two simple 2D
arraysone for the BV and the other for the BH sample sets. Referring to the BV array, the vertical axis corresponds to the index and the horizontal to m (see (4) and (5)). Thus, our array has 2N rows and N columns.
Overall we have 4N 2 frequency sample points, originating from an image of size N N . The factor 4 oversampling is helpful for numerical stability [30]. This data structure implies that when we draw a row or column from
these arrays, we do not necessarily refer to horizontal or vertical set of frequency points, but rather refer to points
along one ray or points along one of the concentric squares.
In our treatment, the processing of the BV and the BH data are completely parallel. Our description will refer to
the BV points only.
2.2. A fast forward transform
Given the pseudo-Polar BV grid points in the frequency domain, we are interested in computing the Fourier transform values. In what follows we shall show that simple 1D-FFT operations can be used to achieve this goal.
151
Theorem 1. Given a 2D signal f [i1 , i2 ], 0 i1 , i2 < N , evaluation of the FT on the pseudo-Polar grid as defined in
(4) and (5) can be done by 1D operations only, and with complexity of 140N 2 log N flops.
Proof. This result can be considered known, applying ideas behind the work of Pasciak [32], Edholm and Herman [33], and Lawton [34] to the pseudo-Polar grid, which, however, is not precisely the grid they considered.
Essentially, the result as stated has been obtained in [30], and is spelled-out here for completeness.
Using the definition of the Fourier transform for discrete functions in Eq. (3), and plugging the coordinates from
Eqs. (4) and (5) we obtain
f(x , y ) = f[m, ] =
N
1 N
1
i1 =0 i2 =0
N
1 N
1
i1 =0 i2 =0
N
1
i1 =0
f [i1 , i2 ] exp i(i1 x + i2 y )
2i1 m i2
f [i1 , i2 ] exp i
+
N
N2
N 1
i2i1 m
ii2
exp
f [i1 , i2 ] exp
.
N
N2
(6)
i2 =0
f1 [i1 , ] =
i2 =0
ii2
f [i1 , i2 ] exp
.
N
(7)
This expression stands for a 1D-FFT on the columns of the zero padded array f [i1 , i2 ]. In order to show this, assume
that f [i1 , i2 ] is zero padded to yield
f [i1 , i2 ], 0 i2 < N,
fZ [i1 , i2 ] =
0,
N i2 < 2N.
Thus,
N
1
f1 [i1 , ] =
i2 =0
2N
1
ii2
i2i2
=
.
f [i1 , i2 ] exp
fZ [i1 , i2 ] exp
N
2N
(8)
i2 =0
This expression stands for 1D-FFT of an array of 2N samples. However, another complicating factor is the range of
(N N 1), as opposed to the regular FFT range that starts at 0. Thus, defining n = + N we get
f1 [i1 , n] =
2N
1
i2 =0
2N
1
i2i2 (n N )
i2i2 n
=
.
fZ [i1 , i2 ] exp
fZ [i1 , i2 ] (1)i2 exp
2N
2N
(9)
i2 =0
To summarize this part, computation of the inner summation (w.r.t. i2 ) amounts to 1D-FFT of length 2N on the
columns of the zero padded and pre-multiplied3 array f [i1 , i2 ] (1)i2 . The amount of operations needed for this
stage are 5 2N log(2N ) per each column,4 and 10N 2 log(2N ) operations for all the N columns.
We return now to Eq. (6) and assume that the above process has been completed. Thus we hold the N 2N array
f1 [i1 , ] and we should proceed by computing the second summation
f[m, ] =
N
1
i1 =0
N
1
i2i1 m
i2i1 m
f1 [i1 , ] exp
f1 [i1 , ] exp
=
.
N
N
N2
(10)
i1 =0
3 We have to multiply our array by (1)i2 , but this could be replaced by later shift, owing to the periodic nature of the transform.
4 We assume hereafter that a regular DFT on a vector of length N requires 5 N log(N ) operations by the FFT algorithm [2]. Although this
applies originally to N being powers of 2, we use it for an arbitrary N , with the understanding that the coefficient may slightly change.
152
Removal of the factor = /N in the exponent turns this expression into a regular 1D-FFT, this time applied on
the rows of the array f1 . With this factor in the above summation, the required operation is known as the Chirp-Z
[37], or the Fractional Fourier Transform (FRFT) [38]. In Appendix A we show how this transform can be computed
efficiently for any , with 30N log N operations, based on 1D-FFT use. As before, due to a shifted range of the
index m, one has either to shift after the transform, or modulate the array, prior to the transform.
To summarize, we have 2N rows that are to be put through a Chirp-Z transform. Thus we need 60N 2 log N operations for this stage. Adding to the previous stage complexity, we get an overall of 70N 2 log N operations for the
computation of the transform for the BV part of the grid. To cover both the BV and the BH grid points we need
140N 2 log N . 2
In this paper the pseudo-Polar grid is a stepping stone toward the Polar coordinates system. Since interpolations
are to be used to convert from pseudo-Polar to Polar coordinates, we should consider computing the pseudo-Polar
FFT on a more densely-spaced grid. We state here without proof the following result: given a 2D signal f [i1 , i2 ],
0 i1 , i2 < N , the evaluation of the FT on the oversampled pseudo-Polar grid with N S concentric squares and 2N P
slope-equispaced rays can be obtained by 1D vector operations only, and with complexity of 120N 2 P S log(N S) flops.
In fact, this result could be shown to follow immediately from Theorem 1 with zero-padding of the original image.
2.3. Fast inverse transform and quasi-Parseval relationship
The pseudo-Polar FFT can be inverted by the method of least-squares (LS) (see [28,30] for the same concept). To
see this, consider a matrixvector formulation of our processes. For an image f [i1 , i2 ] of size N N , we define the
column vector f of length N 2 , containing the image pixel values in column-stack ordering. This vector is multiplied
2
2
by a matrix TPP C 4N N , representing the pseudo-Polar FFT. The outcome of this multiplication is a vector f
of length 4N 2 , containing the samples of the Fourier transform on the pseudo-Polar grid. Given f, inversion of the
pseudo-Polar Fourier transform is achieved by solving
1 H
where T+
PP denotes generalized inverse.
Of course, the matrix-based solution is useless as a computational approach for reasonable sizes of input arrays; a pseudo-direct inversion of the matrix TPP is computationally prohibitive, and definitely beyond the desired
N 2 log(N) complexity. Instead, we approach the optimization problem iteratively by the iteration relation
f k+1 = f k DTH
PP (TPP f k f ).
(12)
The expression TH
PP (TPP x f ) is the functions gradient and the multiplication by a positive definite matrix D guarantees descent in the LS error. If chosen properly, D could speed-up convergence of this algorithm to the true solution,
as posed in (11). In [30] a specific choice of diagonal matrix D is proposed that down-weights near-origin points in
order to equalize the condition number. It is shown that with few (26) iterations this iterative process achieves high
accuracy solutions. As to the initialization, it could be chosen as zeros (f 0 = 0) for simplicity. This way we obtain a
fast inverse transform of the same complexity as the forward one, as every iteration requires the application of both
the forward transform (multiplying with TPP ) and its adjoint (multiplying with TH
PP ). It still remains to be seen that
the adjoint is computable with the same complexity as the forward transform, which is the claim of the next theorem.
Theorem 2. Given a 2D array f[m, ] of size 2N 2N representing a pseudo-Polar grid sampling in the frequency
domain, the evaluation of the adjoint pseudo-Polar FFT to produce an N N image can be done by 1D operations
only, and with complexity of O{N 2 log(N )} operations.
Proof. Posed in a matrix notation, multiplication by TH
PP requires taking the conjugate of each element in the matrix TPP , and summing with respect to columns, rather than rows. Thus, using the relation posed in (6) we have that
the regular (forward) transform is applied by
f[m, ] =
N
1 N
1
i1 =0 i2 =0
153
2i1 m i2
.
f [i1 , i2 ] exp i
+
N
N2
Similarly, referring to the basically vertical (BV) values only, the adjoint is achieved by
f[i1 , i2 ] =
N/21
N
1
m=N/2 =N
N
1
=N
2i1 m i2
+
f [m, ] exp i
N
N2
i2
exp i
N
N/21
m=N/2
2i1 m
.
f[m, ] exp i
N2
(13)
f1 [i1 , ] =
f [m, ] exp i
N
N
m=N/2
and this is a Fractional FFT, just as we obtained with the forward transform. We have seen that this operation could be
done in O{N log(N )} per every , producing N values. Thus, for N N 1 we need to perform O{N 2 log(N )}
operations. Once performed, we then obtain the expression
f[i1 , i2 ] =
N
1
=N
i2
exp i
f1 [i1 , ]
N
(14)
and this is a regular inverse-FFT, which requires O{N log(N )} per every 0 i1 N 1. Thus, again we get that
O{N 2 log(N )} operations are required to conclude this part of the computations.
As a last point in this proof, we should refer similarly to the BH rays. The complete adjoint operation is obtained
by performing the same process as described above, and adding the two resulting arrays. 2
3. From pseudo-Polar to Polar
Similar to the Cartesian-based USFFT approach, we suggest to compute the Polar-FT values based on a different
grid for which a fast algorithm exists, and then go to the Polar coordinates via an interpolation stage. However, instead
of using the Cartesian grid in the first stage, we use the pseudo-Polar grid of the previous section. Since this grid is
closer to the Polar destination coordinates, there is a reason to believe that this approach will lead to better accuracy
and thus lower oversampling requirements. However, as we shall see next, beyond the proximity of the pseudo-Polar
coordinates to the Polar ones, another very important benefit is the ability to perform the necessary interpolations via
pure 1D operations without losing accuracy. This property is vital in understanding the superiority of the proposed
scheme over traditional Cartesian-based USFFT methods.
3.1. Pseudo-PolarPolar: grid conversion
We define the Polar coordinate system based on the pseudo-Polar one, with manipulations that lay out the necessary
interpolation stages discussed later on. Starting from the basically-vertical frequency sampling points in the pseudoPolar grid as given in (4)
N
2m
N
for N < N,
x =
,
BV = y =
for m <
N
2
2
N2
the Polar ones are obtained by two operations:
(1) Rotate the rays. In order to obtain an angularly-uniform ray sampling as in the Polar coordinate system, the rays
must be rotated. This is done by replacing the term 2m/N in x above with tan(m/2N ), leading to the grid
points
154
Fig. 3. The first interpolation stage for rotating the rays. Circles represent the known pseudo-Polar grid points and squares are the desired equiangularly spaced rays.
BV new = y =
N
m
N
N
x =
tan
for m <
.
N
2N
2
2
for N < N,
The result is a set of points organized on concentric squares as before, but the rays are now equispaced in angle
rather than slope. Figure 3 depicts this step as an interpolation stage. Rotating the rays amounts to a 1D operation
along horizontal lines (for the BV points). A set of N equispaced points along this line are replaced by a new set
of N points along the same line in different locations (marked as small squares) implementing equispaced angular
sampling.
An interesting property of this interpolation stage is the fact that the underlying function to be interpolated assumes a simple form, which implies that interpolation accuracy is expected to be high, even for low oversampling
factors. Furthermore, the given points are densely arranged around the desired locations, thus ensuring a better interpolation accuracy (compared to the same number of points spread from end-to-end, as in the Cartesian
USFFT).
Returning to Eq. (6) and referring to a specific row with fixed y , we have
f(m, y ) =
N
1 N
1
i1 =0 i2 =0
2mi1
+ i2 y
f [i1 , i2 ] exp i
N
N 1
N
1
i1 =0
i2 =0
N
m
1
2mi1
2i1
y =
y
exp(iy i2 )f [i1 , i2 ] exp i
C[i1 ] exp i
N
N
(15)
i1 =0
155
Fig. 4. Second interpolation stage for circling the squares. Small circular points represent the known grid points after the previous interpolation
stage, and the square points are the desired final interpolated values.
(2) Circle the squares. In order to obtain concentric circles as required in the Polar coordinate system, we need to
circle the squares. This is done by dividing both x and y by a constant along each ray, based on its angle, and
therefore a function of the parameter m, being
m
2
.
(16)
R[m] = 1 + tan
2N
The resulting grid is given by
y = N R[m]
for N < N
m
for N2 m <
x = N R[m] tan 2N
N
2
Figure 4 depicts this step as an interpolation stage. Circling the squares amounts to a 1D operation along rays.
A set of 2N equispaced points is replaced by a new set of 2N points along the same line in different locations
(marked as small squares). This time the destination points are equispaced, but with a different spacing.
We have seen above that the first interpolation stage is applied on a trigonometric polynomial, which explains the
expected accuracy obtained. In this later stage, the function over which we interpolate is not of the same simple
form, but nevertheless smooth enough. Referring to one ray of slope (in the range [1, 1], considering the BH
rays) we have that the 1D slice to work on is given by
f(x , y ) =
N
1 N
1
1 N
1
N
f [i1 , i2 ] exp i(i1 x + i2 y ) =
f [i1 , i2 ] exp i(i1 + i2 )x = f(x ).
i1 =0 i2 =0
i1 =0 i2 =0
Consider the function f(z) described above as a 1D function and take its Fourier transform
F f(z) =
f(z) exp(iz) dz =
N
1 N
1
i1 =0 i2 =0
f [i1 , i2 ] exp i(i1 + i2 )z exp(iz) dz
156
N
1 N
1
f [i1 , i2 ] (i1 + i2 + ).
i1 =0 i2 =0
Here (i1 + i2 ) is the Dirac function, being nonzero for i1 + i2 = 0. This expression assumes its
maximal frequency at i1 = i2 = N 1 and its minimal frequency at i1 = i2 = 0. The frequency support of this
function is the interval [(N 1)(1 + ), 0]. Thus, for = 1 we obtain the widest bandwidth of 2N , and then
the Nyquist-sampling rate for this function is Tmax = /N .
This means that the Fourier transform f restricted to the ray is a band-limited function with required maximal
sampling period of /N . If this function is sampled in this rate along the entire ray (from to ) we have a
complete representation of it that enables knowledge of its values at any location. In our case, for a limited interval
z [, ] we have 2N samples, which is the critical sampling rate exactly. Thus, with a moderate oversampling
we may expect to represent this function very accurately. This implies that this function is relatively smooth as
well and lends itself to high-accuracy interpolation.
3.2. The proposed schemeoverview
In performing the proposed Polar-FFT, we start with computation of the Fourier transform over a pseudo-Polar
grid, followed by the two interpolation stages presented above. As we have seen, in order to obtain high accuracy,
the pseudo-Polar grid should be oversampled, both radially and angularly. One approach to oversampling is the use
of the over-sampled pseudo-Polar grid as presented in the previous section (e.g., by zero padding). Alternatively,
as the pseudo-Polar fast transform can be broken into two parts, this separation could be used for better efficiency.
For the BV coordinates, the vertical FFT can be done with oversampling by zero padding as before, and then, as
we go to the second phase of Fractional FFT per each row, we can apply this stage one row at a time with the
interpolation that leads directly to the rotated rays. The memory savings are substantial (directly proportional to the
oversampling factor P ). Note that in performing the 1D interpolations, complete rows or columns from the result
array are brought to the cache, and processed to produce the desired values. Thus, memory management becomes
extremely effective, as opposed to the regular USFFT methods that require general memory access that may lead to
many cache misses.
As for the complexity of the overall algorithm, we have seen before that an amount of 120N 2 SP log2 (N S) operations are required for the computation of the oversampled pseudo-Polar FFT. Those operations are followed by
the first interpolation requiring O(N 2 S) operations (every row uses N P points to compute N values requires O(N )
operations, and there are N S of those). The second interpolation requires O(N 2 ) operations (every ray with 2N S
values is used to produce 2N new values, and there are N rays). Thus, the overall operation count is dominated by
the 120N 2 SP log2 (N S) operations of the pseudo-Polar FFT. This is 12SP times more complex than plain N N
Cartesian grid 2D-FFT.
In terms of memory requirements, the overcomplete pseudo-Polar FFT requires 4N 2 SP float-values, and once
those are allocated, all other operations can be done within this array. Alternatively, using row-wise interpolation,
only 4N 2 S values are required. Also, a factor 2 saving can be obtained if a proper separation between the basically
vertical and basically horizontal parts is applied. Further savings could be obtained by breaking each of these groups
(BV and BH) to sub-parts with small overlap.
All the above applies to a general image of size N N , resulting with an output Polar FT array of size 2N 2N .
If higher oversampling is desired in the destination grid, all the above is still applicable. One simple way to get such
oversampling is to zero-pad the input array (this way modifying the initial N ).
The inversion of the Polar-FFT requires an implementation of the inverse pseudo-Polar FFT as described in the
previous section. Starting with a set of Polar coordinates in the frequency domain, we first apply two interpolation
stagessquaring the circles, and then rotating the raysjust as described above but in reversed order. For such
operation to succeed, we assume that the Polar grid is given in an over-complete manner (i.e., we start with an
array of 2N P [rays] 2N S[circles] and interpolate to a pseudo-Polar grid with 2N [rays] 2N [squares]). Once those
coordinates are filled with values, inverse pseudo-Polar FFT is applied as described previously, using the adjoint
operator. The same arguments posed above explain the suitability of the 1D interpolation and their expected accuracy
in the above reverse process.
157
Fig. 5. The frequency support options: the outer square stands for the original frequency support of an arbitrary digital image. The inscribed disk
stands for the required support for the Polar-FFT to behave well. The smaller square inside is the one archived by the simple re-sampling proposed,
where the number of pixels in the image is increased by factor 2.
imageis sampled
at
2
times
the Nyquist rate on both Cartesian axes then its frequency domain support is the square
158
Fig. 6. The condition-number for the transform matrix for a direct Polar-coordinates transform and for an augmented one, that nulls the corners.
that refer to the corners (outside the -radius disk). Roughly speaking, we have doubled the number of rows, and the
condition-number this time is well controlled. For an input array of size 30 30 the condition number is 6.6, meaning
that standard iterative techniques of linear algebra achieve a high accuracy inversion.
This numerical experiment comes to show that zero-forcing at the corners stabilizes the inversion process. However,
in practice, there is no need for the augmentation as done in the prescribed experimentall that is needed is nulling
values outside the frequency support disk of radius , and the improved condition-number presented here holds true
nevertheless.
4. Analysis of the Polar FFT algorithm
4.1. Experimental evidenceUSFFT versus Polar-FFT
We apply the USFFT and the Polar-FFT tools to the image Lena (scaled down to size 64 64 pixels, in order
to speedup this and later experiments), and compare error behaviors. In particular, we are interested in studying the
effect of the oversampling. Figure 7 presents the results of the first experiment.
For the Cartesian-based USFFT method, we use a 2D Hermite interpolation on a 2 2 support [39]. It exploits
known Fourier values on the Cartesian grid, along with their horizontal and vertical derivatives (altogether, 12 values),
in order to fit a polynomial. Those directional derivatives are obtained by pre-multiplying the image by linear terms
and applying the 2D-FFT three times [21]. For the pseudo-Polar based method, the first interpolation stage is also
based on Hermite interpolation with a 2-samples support (as for the USFFT, but applied in 1D, and exploiting 4
known values on this support to fit a cubic). The second stage interpolation uses a piecewise cubic spline using the
Fourier values alone and forcing alignment of the first derivatives6 [39]. Thus, the interpolation schemes deployed
on our Polar-FFT are inferior to the one practiced for the Cartesian-USFFT. Those schemes remain fixed throughout
the reported experiments. As already mentioned in the Introduction, better interpolation methods can be used for both
algorithms. Here we chose to concentrate on short-support and relatively simple methods that are easy to understand
and implement, and ones that eventually lead to an acceptable level of accuracy, nevertheless.
Figure 7 presents both 1 and 2 measures of error. The error presented is a relative error, normalized by the
appropriate norm of the ideal result. The horizontal axis in the plots is the overall oversampling ratio. For the Cartesianbased USFFT, for an oversampling factor of S in each axis, the overall oversampling ratio is S 2 . Similarly, for our
6 Evaluating the directional derivatives for this stage requires a replication of the first stage interpolation for those as well, and thus was avoided,
settling for a weaker scheme.
159
Fig. 7. USFFT and the Polar-FFT error as a function of the over-sampling. The USFFT oversampling is the same along the two axes, while for the
PFFT we fix the angular oversampling (P = 1, 2, . . . , 6, and thus 6 curves) and vary the radial one S = 1, 2, . . . , 20.
method, the overall oversampling is P S, where S and P are the oversampling ratios for the number of squares and
number of rays. Several choices of P and S are tested.
We see that for the proper choice of P and S (S 5P ) the Polar-FFT method is far more accurate than the USFFT,
under either error measure. For a fixed P there is a saturation effect in the approximation error as S because
errors caused by the first interpolation stage dominate and cannot be compensated. The higher needed oversampling
along the rays can be explained in two ways: (i) the radial interpolation stage of the PFFT uses a lower-order procedure,
based on splines instead of Hermite interpolation; and (ii) the radial interpolation task is more difficult as the signal
to be interpolated is less smooth (see previous section). Extensive experiments with different signals, their sizes, and
metrics of error evaluations, all confirm that the above conclusions comparing the two methods are typical.
4.2. Frequency domain spread of the error
Given the specific image and fixing the oversampling ratio, we study how the errors of the two methods behave in
the frequency domain. Intuitively, we know that Cartesian-based USFFT method should cause higher errors near the
origin where the interpolation starts from an inherently coarser grid. In contrast, we expect the Polar-FFT to perform
equally well in most frequency locations.
Using the same test image from the previous experiment (scaled down Lena), Fig. 8 shows the relative errors
obtained by the USFFT (S = 9 in both axes), and the Polar-FFT (S = 20, P = 4). The plots show log (with base
10, being crucial for a good visualization) of the absolute value of the transform errors, divided by the mean absolute
value of the true transform, so as to get a relative error evaluation. The frequency domain is presented on Cartesian
axes in order to give more intuitive frequency-content description. Since the frequency domain is sampled in Polar
coordinates in the transforms, we use a Voronoi diagram to slice the plane into pieces per each Polar frequency sample.
This is a matter of visual display only.
Our expectations about the distribution of errors in the frequency domain are validatedthe Cartesian-USFFT
concentrates the error at the origin, while the Polar-FFT errors are spread around. Moreover, the errors obtained by
the Polar-FFT are substantially smaller.
160
Fig. 8. The relative error as a function of frequency location using a specific image. This figure shows the error obtained by the USFFT method
(left) and the PFFT algorithm errors (right). The error scale is relative and logarithmic.
W(Te Tu )x22
x22
(17)
W is a diagonal matrix with all entries being zero apart from the one element chosen in the frequency domain. Thus,
essentially, only one row of the matrix Te Tu is useddenote this as eT . Clearly, by Cauchys inequality, the
maximum is obtained for x = e, and the error obtained is e2 .
Figure 9 presents these worst-case errors7 as a function of frequency for both methods when N = 16. The PolarFFT performs far better in all locations. Note that our relatively low choice of N = 16 in this experiment causes
special sampling effects.
7 In this and later experiments based on the matrixvector representation of the transforms, we use low value for N because of the induced matrix
sizes. One could use much higher N values if instead of explicitly forming the matrices, the transform and its adjoint operator are applied.
161
Fig. 9. The error as a function of frequency location: using the worst case signal per location (left: USFFT, right: the proposed Polar-FFT).
(Te Tu )x22
x22
(18)
seeking the worst-possible signal x maximizing error, subject to unit 2 -norm. The answer is of-course the first right
singular vector of (Te Tu ) [40] and the value of (18) is the square of the first singular value (a square-root is required
to align with previous error measures).8
Figure 10 presents the real and imaginary parts of these worst-case signals for the USFFT (S = 9) and the PolarFFT (S = 20, P = 4), and the absolute frequency description of this signal. The USFFTs maximal square-root MSE
error is 3.6 103 while the Polar-FFTs is 1.9 104 . Again, the USFFT method is weaker, and its worst signal is
concentrated near the frequency origin where the method is weakest. Note that the worst signal is modulated (notice
the shift from the center in the spatial domain) to result in a very nonsmooth frequency behavior.
4.4.2. Relative approach
A major problem with the above analysis is the difficulty in understanding the meaning of the error found, being
a ratio between energies in the frequency and the spatial domains. An interesting alternative is the definition of worst
signals by
max
x
(Te Tu )x22
Te x22
(19)
Put in words, we seek the worst error relative to transform size in Polar frequency coordinates. This problem amounts
to a generalized eigenvalue problem [40]. Figure 11 presents the results for Cartesian USFFT method (maximal error
is 3.6 104 ) and Polar-FFT method (worst error is 4.5 105 ). Both methods lead to similar worst-case signals,
8 Alternatively, the objective function defined in (18) can be maximized by an eigendecomposition of the symmetric and positive semi-definite
matrix (Te Tu )H (Te Tu ), and taking the eigenvector that corresponds to the largest eigenvalue. This is theoretically equivalent to the SVD
approach mentioned above.
162
Fig. 10. Worst case signaldirect eigenvalue approach. The top row shows the worst signal for the USFFTthe real spatial part (left), the imaginary
spatial part (middle), and its spectrum (right). The bottom row shows the same for the PFFT.
Fig. 11. Worst case signalrelative eigenvalue approach. The top row shows the worst signal for the USFFTthe real spatial part (left), the
imaginary spatial part (middle), and its spectrum (right). The bottom row shows the same for the PFFT.
with energy mostly falling outside the circle of radius , so that the denominator in the above definition is nearly zero.
Nevertheless, our Polar-FFT has an advantages over Cartesian coordinates.
4.4.3. Relative approach with support constraint
In order to avoid signals of the sort obtained earlier, we seek the worst case signal for (19) with the side-constraint
of no energy in the frequency domain outside the circle of radius . Thus we solve
max
(Te Tu )x22
Te x22
subject to F1 x = 0,
(20)
where F1 represents the regular Cartesian FFT in a predetermined density, restricted to frequency points outside the
circle. Alternatively, we reformulate this using
max
{x|F1 x=0}
(Te Tu )x22
Te x22
max
x
(Te Tu )x22
Te x22 + F1 x22
(21)
With this formulation we again have a generalized eigenvalue problem. For large , (21) yields an approximate solution of the original problem (20). We chose = 1000 and find that higher values does not change the results
163
Fig. 12. Worst case signalrelative eigenvalue approach with constraint. The top row shows the worst signal for the USFFTthe real spatial part
(left), the imaginary spatial part (middle), and its spectrum (right). The bottom row shows the same for the PFFT.
perceivably. Those results are shown in Fig. 12. The USFFT worst error is 6.5 105 and with the Polar-FFT method
the error we obtain is 4.2 106 .
4.5. Signal-space ordering via eigenspace analysis
We return to the definition of error in Eq. (19). In solving the maximization problem for the Polar-FFT we find
the worst signal and the accompanying worst error. This worst signal represents only a one-dimensional subspace of
signals, and for signals orthogonal to it, all we can say is that the error on their transform computation is expected to
be smaller, though we cannot say by how much.
Solving the same problem again while forcing the result to be orthogonal to the previous eigenvector (the already
found worst-possible signal), we obtain a second worst rank-1 sub-space. Repeating this process, we essentially find
ranked orthonormal basis that represents the signal-space CN N , such that the first vector spans the worst signals, the
second spans the next worst signals, and so on. The process described above is simply an eigenvalue problem for
the matrix
(Te Tu )H (Te Tu ).
The eigenvectors are the ranked ortho-basis and the eigenvalues are related squared errors. Denote the results of the
2
above process on the Polar-FFT error by {uk }k=N
k=1 , such that uN 2 is the worst signal. Then the sequence
2
{k }N
k=1 =
N 2
(22)
k=1
measures the errors induced by each subspace, from ranked best to the worst. Using the same ortho-basis, we may
compute
2
164
165
Fig. 15. The ranked signal spacethe relative eigenvalue approach with constraints.
6. Conclusions
In this article we have developed a rapid and accurate Polar FFT. For a given two-dimensional signal of size N N ,
the proposed algorithm produces a Polar FFT with C N 2 coordinate samples, where C is a chosen parameter (e.g.,
C = 4). The complexity of this algorithm is O(CN 2 log N ), just like in a Cartesian 2D-FFT. Two special features of
this algorithm are (i) it involves only 1D equispaced FFTs and 1D interpolations, leading to a highly cache-aware
algorithm; and (ii) it has very high accuracy for moderate oversampling factors.
The accuracy of the algorithm was studied both for specific images and from a worst-case standpoint. The new
approach is shown to be far more accurate than Cartesian-based Unequally-Spaced Fast Fourier Transform (USFFT).
Our analysis shows that the proposed scheme produces highly accurate transform values near the origin, where typical signals concentrate on. However, these comparative results are restricted to the use of simple and small-support
interpolations and no pre-compensation. Further work is required in order to incorporate more advanced techniques
from the USFFT literature.
In the present paper we emphasize the basic construction, leaving aside applications, improvements, and extensions.
We believe that this paper serves the researchers/engineers interested in applying those tools in applications, offering
a reasonable confidence in the accuracy and speed. The supplied software, along with this documentation, may make
the adoption of these methods relatively painless.
Future work on this topic might consider various improvements to the interpolation stages implemented in our
algorithm, using recent results in the USFFT literature (e.g., [28,29]). The proposed algorithm might have applications
in stable and rapid inversion of Radon transform, fast image rotation and registration, and elsewhere. Extension to 3D
will require definition of Polar-like9 coordinates.
Appendix A. Chirp-Z transform (FRFT)
Definition 3. Given the discrete signal x[n] over the support 0 n < N , and given an arbitrary scalar value , the
Chirp-Z Transform (also known as the Fractional Fourier Transform) is given by
x[k]
=
N
1
n=0
i2kn
x[n] exp
N
for 0 k < N.
9 There is no exact Polar sampling method for 3D, thus we must settle for Polar-like grids.
(A.1)
166
As we have seen through the definition of the pseudo-Polar Fourier transform, we need to perform this kind of
transform as part of our process. The following theorem guarantees existence of a highly efficient algorithm for this
transform. This theorem, and more importantly, the efficient process itself, are described in [37,38].
Theorem 4. Evaluation of the Chirp-Z transform can be done with order of 30N log N operations.
Proof. Our proof will be given by construction of such an efficient process. Our starting point is the trivial assignment
2kn = k 2 + n2 (k n)2 . Using this relationship into the definition above we obtain
N
1
i 2
x[k]
=
k + n2 (k n)2
x[n] exp
N
n=0
N 1
i
i 2
i 2
2
x[n] exp
= exp
k
n exp
(k n) .
N
N
N
(A.2)
n=0
N
1
x[n]s[n]s[k n].
(A.3)
n=0
This equation suggests a way to evaluate the transform, starting with pre-multiplication of x[n] by s[n], followed by
a convolution with s[n], and finally, post-multiplying with s[n] again.
The main saving in computation comes from replacing convolution by a 1D-FFT based method. A 1D-FFT transform should be applied on the two sequences, multiply the results, and apply inverse transform on the resulting
sequence. FFT should be computed for the two sequences with zero padding to length 2N in order to avoid cyclic
effects.
Three 1D-FFTs are needed, costing each 10N log N operations. The creation of s[n] and the pre-/postmultiplication by it require O(N ) additional operations. Thus, an overall of 30N log N operations is needed for
the entire process, as claimed by the theorem. 2
References
[1] J. Dongarra, F. Sullivan, Introduction the top 10 algorithms, Comput. Sci. Eng. 2 (1) (2000) 2279. Special issue.
[2] B. Briggs, E. Henson, The FFT: An Owners Manual for the Discrete Fourier Transform, SIAM, Philadelphia, 1995.
[3] A. Averbuch, R.R. Coifman, D.L. Donoho, M. Elad, M. Israeli, Accurate and fast Polar Fourier transform, in: The 37th Asilomar on Signals,
Systems and Computers, Pacific Grove, CA, 2003.
[4] F. Natterer, The Mathematics of Computerized Tomography, John Wiley & Sons, New York, 1986.
[5] H. Stark, J.W. Woods, I. Paul, R. Hingorani, Direct Fourier reconstruction in computer tomography, IEEE Trans. Acoust., Speech Signal
Process. 29 (2) (1981) 237245.
[6] H. Fan, J.L.C. Sanz, Comments on Direct Fourier reconstruction in computer tomography, IEEE Trans. Acoust., Speech Signal
Process. 33 (2) (1985) 446449.
[7] S. Matej, M. Vajtersic, Parallel implementation of the direct Fourier reconstruction method in tomography, Comput. Artificial Intelligence 9 (4)
(1990) 379393.
[8] K.J. Moraski, D.C. Munson Jr., Fast tomographic reconstruction using Chirp-Z interpolation, in: Proc. 25th Asilomar Conference on Signals,
Systems, and Computers, Pacific Grove, CA, IEEE Comput. Soc. Press, Los Alamitos, CA, 1991, pp. 10521056.
[9] A.H. Delaney, Y. Bresler, A fast and accurate Fourier algorithm for iterative parallel-beam tomography, IEEE Trans. Image Process. 5 (5)
(1996) 740753.
[10] H. Choi, D.C. Munson Jr., Direct-Fourier reconstruction in tomography and synthetic aperture radar, Int. J. Imaging Systems Technol. 9 (1)
(1998) 113.
[11] J. Walden, Analysis of the direct Fourier method for computer tomography, IEEE Trans. Medical Imaging 19 (3) (2000) 211222.
[12] D. Gottleib, B. Gustafsson, P. Forssen, On the direct Fourier method for computer tomography, IEEE Trans. Medical Imaging 19 (3) (2000)
223232.
167
[13] F. Natterer, F. Wbbeling, Mathematical Methods in Image Reconstruction, SIAM, Philadelphia, 2000.
[14] S. Basu, Y. Bresler, An O(n2 log n) filtered backprojection reconstruction algorithm for tomography, IEEE Trans. Image Process. 9 (10)
(2000) 17691773.
[15] K. Fourmont, Non-equispaced fast Fourier transforms with applications to tomography, J. Fourier Anal. Appl. 9 (2003) 431450.
[16] S. Matej, J.A. Fessler, I.G. Kazantsev, Iterative tomographic image reconstruction using Fourier-based forward and back-projectors, IEEE
Trans. Medical Imaging 23 (4) (2004) 401412.
[17] E. Suli, A. Ware, A spectral method of characteristics for hyperbolic problems, SIAM J. Numer. Anal. 28 (2) (1991) 423445.
[18] J.P. Boyd, Multipole expansions and pseudospectral cardinal functions: A new generalization of the fast Fourier transform, J. Comput.
Phys. 103 (2) (1992) 184186.
[19] J.P. Boyd, A fast algorithm for Chebyshev, Fourier, and sinc interpolation onto an irregular grid, J. Comput. Phys. 103 (2) (1992) 243257.
[20] G. Beylkin, On the fast Fourier transform of functions with singularities, Appl. Comput. Harmon. 2 (1995) 263381.
[21] C. Anderson, M.D. Dahleh, Rapid computation of the discrete Fourier transform, SIAM J. Sci. Comput. 17 (1998) 913919.
[22] A. Dutt, V. Rokhlin, Fast Fourier transforms for nonequispaced data, SIAM J. Sci. Comput. 14 (1993) 13681393.
[23] A. Dutt, V. Rokhlin, Fast Fourier transforms for nonequispaced data II, Appl. Comput. Harmon. Anal. 2 (1995) 85100.
[24] A.F. Ware, Fast approximate Fourier transform for irregularly spaced data, SIAM Rev. 40 (4) (1998) 838856.
[25] D. Potts, G. Steidl, M. Tasche, Fast Fourier transforms for nonequispaced data: A tutorial, in: J.J. Benedetto, P. Ferreira (Eds.), Modern
Sampling Theory: Mathematics and Application, Birkhuser, 2000, pp. 253274, ch. 12.
[26] A.J.W. Duijndam, M.A. Schonewille, Nonuniform fast Fourier transform, Geophysics 64 (2) (1999) 539551.
[27] N. Nguyen, Q.H. Liu, The regular Fourier matrices and nonuniform fast Fourier transforms, SIAM J. Sci. Comput. 21 (1) (1999) 283293.
[28] J.A. Fessler, B.P. Sutton, Nonuniform fast Fourier transforms using minmax interpolation, IEEE Trans. Signal Process. 51 (2) (2003) 560
574.
[29] L. Greengard, J.Y. Lee, Accelerating the nonuniform fast Fourier transform, SIAM Rev. 46 (2004) 443454.
[30] A. Averbuch, R. Coifman, D.L. Donoho, M. Israeli, Fast Slant Stack: A notion of Radon transform for data in a Cartesian grid which is rapidly
computible, algebraically exact, geometrically faithful and invertible, Technical Report, Statistics Department, Stanford University, 2003.
[31] R.M. Mersereau, A.V. Oppenheim, Digital reconstruction of multidimensional signals from their projections, Proc. IEEE 62 (10) (1974)
13191338.
[32] J.E. Pasciak, A note on the Fourier algorithm for image reconstruction, Preprint AMD 896, Applied Mathematics Department, Brookhaven
National Laboratory, Upton, NY, 1981.
[33] P. Edholm, G.T. Herman, Linograms in image reconstruction from projections, IEEE Trans. Medical Imaging MI-6 (4) (1987) 301307.
[34] W. Lawton, A new Polar Fourier-transform for computer-aided tomography and spotlight synthetic aperture radar, IEEE Trans. Acoust.,
Speech Signal Process. 36 (6) (1988) 931933.
[35] A. Averbuch, Y. Shkolnisky, 3D Fourier based discrete Radon transform, Appl. Comput. Harmon. Anal. 15 (1) (2003) 3369.
[36] Y. Keller, A. Averbuch, M. Israeli, A pseudoPolar FFT technique for translation, rotation and scale-invariant image registration, IEEE Trans.
Image Process. 14 (1) (2005) 1222.
[37] L.R. Rabiner, R.W. Schafer, C.M. Rader, The Chirp Z-transform algorithm and its application, Bell System Tech. J. 48 (1969) 12491292.
[38] D.H. Bailey, P.N. Swarztrauber, The fractional Fourier transform and applications, SIAM Rev. 33 (3) (1991) 389404.
[39] G. Strang, Introduction to Applied Mathematics, Wellesley/Cambridge Press, 1986.
[40] G.H. Golub, C.F. Van Loan, Matrix Computations, third ed., John Hopkins Univ. Press, 1996.
[41] J. Buckheit, D.L. Donoho, WaveLab and Reproducible Research, Wavelets and Statistics, Springer-Verlag, Berlin, 1995.
[42] C.S. Choi, D.L. Donoho, A.G. Flesia, X. Huo, O. Levi, D. Shi, About BeamLab a Toolbox for New Multiscale Methodologies, Stanford
UniversityStatistics Department Technical Report, http://www-stat.stanford.edu/~beamlab, 2002.