| S2kit
    1.1
    Toolkit for working with functions defined on the sphere | 
#include <fftw3.h>Go to the source code of this file.
| Functions | |
| void | DLTSemi (double *, const int, const int, double *, double *, double *, double *, fftw_plan *) | 
| Computes the Legendre transform of data using the seminaive algorithm.  More... | |
| void | InvDLTSemi (double *, const int, const int, double *, double *, double *, double *, fftw_plan *) | 
| Computes the inverse Legendre transform using the transposed seminaive algorithm.  More... | |
| void DLTSemi | ( | double * | data, | 
| const int | bw, | ||
| const int | m, | ||
| double * | result, | ||
| double * | workspace, | ||
| double * | cos_pml_table, | ||
| double * | weights, | ||
| fftw_plan * | plan | ||
| ) | 
Computes the Legendre transform of data using the seminaive algorithm.
The forward transform looks like:
 where f is the data vector, W is a quadrature matrix, C is a cosine transform matrix, P is a matrix full of coefficients of the cosine series representation of each Pml function P(m,m) P(m,m+1) ... P(m,bw-1), and l is the (associated) Legendre series representation of f.
| data | array of size 2*bwcontaining function to be transformed, assumes sampling at Chebyshev nodes | 
| bw | bandwidth of the problem | 
| m | order of the problem | 
| result | array of length bw for returning computed Legendre coefficients, contains bw-mcoeffs, with the<f,P(m,m)>coefficient located inresult[0] | 
| workspace | space for computations of size 4*bw | 
| cos_pml_table | array containing the cosine series coefficients of the Pmls (or Gmls) for this problem | 
| weights | array of size 4*bwwhich holds the weights for both even (starting atweights[0]) and odd (weights[2*bw]) transforms | 
| plan | pointer to fftw_planwith input array being weighted_data and output being cos_data | 
cos_pml_table should be generated with GenerateCosPmlTable(). The offset for a particular Pml can be found with TableOffset(), the size of the table - with the TableSize(). Since the cosine series are always zero-striped, the zeroes have been removed. weights should be generated by GenerateWeightsForDLT(). plan should be:fftw_plan_r2r_1d(2*bw, weighted_data, cos_data, FFTW_REDFT10, FFTW_ESTIMATE) Definition at line 153 of file seminaive.c.
| void InvDLTSemi | ( | double * | coeffs, | 
| const int | bw, | ||
| const int | m, | ||
| double * | result, | ||
| double * | trans_cos_pml_table, | ||
| double * | sin_values, | ||
| double * | workspace, | ||
| fftw_plan * | plan | ||
| ) | 
Computes the inverse Legendre transform using the transposed seminaive algorithm.
Because the Legendre transform is orthogonal, the inverse can be computed by transposing the matrix formulation of the problem.
(see the description of DLTSemi() for forward Legendre transform)
Then to do the inverse:
so we need to transpose the matrix P from the forward transform and then do a cosine series evaluation. No quadrature matrix is necessary. If order m is odd, then there is also a sin factor that needs to be taken into account.
| coeffs | array of length bw-mcontaining associated Legendre series coefficients, assumed that first entry contains theP(m,m)coefficient | 
| bw | problem bandwidth | 
| m | order of the associated Legendre functions | 
| result | array of 2*bwsamples representing the evaluation of the Legendre series at2*bwChebyshev nodes | 
| trans_cos_pml_table | array of the linearized form of trans(P)from the description of this function | 
| sin_values | array is used when mis odd in generation of the values intrans(P) | 
| workspace | space for computations of size 2*bw | 
| plan | pointer to fftw_planwith input array being fcos and output being result | 
trans_cos_pml_table should be generated by TransposeCosPmlTable(). plan should be:fftw_plan_r2r_1d(2*bw, fcos, result, FFTW_REDFT01, FFTW_ESTIMATE) Definition at line 56 of file seminaive.c.