public class FloatFFT_1D extends Object
| Constructor and Description |
|---|
FloatFFT_1D(int n)
Creates new instance of FloatFFT_1D.
|
| Modifier and Type | Method and Description |
|---|---|
void |
complexForward(float[] a)
Computes 1D forward DFT of complex data leaving the result in
a. |
void |
complexForward(float[] a,
int offa)
Computes 1D forward DFT of complex data leaving the result in
a. |
void |
complexInverse(float[] a,
boolean scale)
Computes 1D inverse DFT of complex data leaving the result in
a. |
void |
complexInverse(float[] a,
int offa,
boolean scale)
Computes 1D inverse DFT of complex data leaving the result in
a. |
void |
realForward(float[] a)
Computes 1D forward DFT of real data leaving the result in
a . |
void |
realForward(float[] a,
int offa)
Computes 1D forward DFT of real data leaving the result in
a . |
void |
realForwardFull(float[] a)
Computes 1D forward DFT of real data leaving the result in
a . |
void |
realForwardFull(float[] a,
int offa)
Computes 1D forward DFT of real data leaving the result in
a . |
void |
realInverse(float[] a,
boolean scale)
Computes 1D inverse DFT of real data leaving the result in
a . |
void |
realInverse(float[] a,
int offa,
boolean scale)
Computes 1D inverse DFT of real data leaving the result in
a . |
protected void |
realInverse2(float[] a,
int offa,
boolean scale) |
void |
realInverseFull(float[] a,
boolean scale)
Computes 1D inverse DFT of real data leaving the result in
a . |
void |
realInverseFull(float[] a,
int offa,
boolean scale)
Computes 1D inverse DFT of real data leaving the result in
a . |
public FloatFFT_1D(int n)
n - size of datapublic void complexForward(float[] a)
a. Complex number is stored as two
float values in sequence: the real and imaginary part, i.e. the size of the input array must be greater or equal
2*n. The physical layout of the input data has to be as follows:a[2*k] = Re[k], a[2*k+1] = Im[k], 0<=k<n
a - data to transformpublic void complexForward(float[] a,
int offa)
a. Complex number is stored as two
float values in sequence: the real and imaginary part, i.e. the size of the input array must be greater or equal
2*n. The physical layout of the input data has to be as follows:a[offa+2*k] = Re[k], a[offa+2*k+1] = Im[k], 0<=k<n
a - data to transformoffa - index of the first element in array apublic void complexInverse(float[] a,
boolean scale)
a. Complex number is stored as two
float values in sequence: the real and imaginary part, i.e. the size of the input array must be greater or equal
2*n. The physical layout of the input data has to be as follows:a[2*k] = Re[k], a[2*k+1] = Im[k], 0<=k<n
a - data to transformscale - if true then scaling is performedpublic void complexInverse(float[] a,
int offa,
boolean scale)
a. Complex number is stored as two
float values in sequence: the real and imaginary part, i.e. the size of the input array must be greater or equal
2*n. The physical layout of the input data has to be as follows:a[offa+2*k] = Re[k], a[offa+2*k+1] = Im[k], 0<=k<n
a - data to transformoffa - index of the first element in array ascale - if true then scaling is performedpublic void realForward(float[] a)
a . The physical layout of the output
data is as follows:a[2*k] = Re[k], 0<=k<n/2 a[2*k+1] = Im[k], 0<k<n/2 a[1] = Re[n/2]if n is odd then
a[2*k] = Re[k], 0<=k<(n+1)/2 a[2*k+1] = Im[k], 0<k<(n-1)/2 a[1] = Im[(n-1)/2]This method computes only half of the elements of the real transform. The other half satisfies the symmetry condition. If you want the full real forward transform, use
realForwardFull. To get back the
original data, use realInverse on the output of this method.a - data to transformpublic void realForward(float[] a,
int offa)
a . The physical layout of the output
data is as follows:a[offa+2*k] = Re[k], 0<=k<n/2 a[offa+2*k+1] = Im[k], 0<k<n/2 a[offa+1] = Re[n/2]if n is odd then
a[offa+2*k] = Re[k], 0<=k<(n+1)/2 a[offa+2*k+1] = Im[k], 0<k<(n-1)/2 a[offa+1] = Im[(n-1)/2]This method computes only half of the elements of the real transform. The other half satisfies the symmetry condition. If you want the full real forward transform, use
realForwardFull. To get back the
original data, use realInverse on the output of this method.a - data to transformoffa - index of the first element in array apublic void realForwardFull(float[] a)
a . This method computes the full real
forward transform, i.e. you will get the same result as from complexForward called with all
imaginary parts equal 0. Because the result is stored in a, the size of the input array must greater
or equal 2*n, with only the first n elements filled with real data. To get back the original data, use
complexInverse on the output of this method.a - data to transformpublic void realForwardFull(float[] a,
int offa)
a . This method computes the full real
forward transform, i.e. you will get the same result as from complexForward called with all
imaginary part equal 0. Because the result is stored in a, the size of the input array must greater
or equal 2*n, with only the first n elements filled with real data. To get back the original data, use
complexInverse on the output of this method.a - data to transformoffa - index of the first element in array apublic void realInverse(float[] a,
boolean scale)
a . The physical layout of the input data
has to be as follows:a[2*k] = Re[k], 0<=k<n/2 a[2*k+1] = Im[k], 0<k<n/2 a[1] = Re[n/2]if n is odd then
a[2*k] = Re[k], 0<=k<(n+1)/2 a[2*k+1] = Im[k], 0<k<(n-1)/2 a[1] = Im[(n-1)/2]This method computes only half of the elements of the real transform. The other half satisfies the symmetry condition. If you want the full real inverse transform, use
realInverseFull.a - data to transformscale - if true then scaling is performedpublic void realInverse(float[] a,
int offa,
boolean scale)
a . The physical layout of the input data
has to be as follows:a[offa+2*k] = Re[k], 0<=k<n/2 a[offa+2*k+1] = Im[k], 0<k<n/2 a[offa+1] = Re[n/2]if n is odd then
a[offa+2*k] = Re[k], 0<=k<(n+1)/2 a[offa+2*k+1] = Im[k], 0<k<(n-1)/2 a[offa+1] = Im[(n-1)/2]This method computes only half of the elements of the real transform. The other half satisfies the symmetry condition. If you want the full real inverse transform, use
realInverseFull.a - data to transformoffa - index of the first element in array ascale - if true then scaling is performedprotected void realInverse2(float[] a,
int offa,
boolean scale)
public void realInverseFull(float[] a,
boolean scale)
a . This method computes the full real
inverse transform, i.e. you will get the same result as from complexInverse called with all
imaginary part equal 0. Because the result is stored in a, the size of the input array must greater
or equal 2*n, with only the first n elements filled with real data.a - data to transformscale - if true then scaling is performedpublic void realInverseFull(float[] a,
int offa,
boolean scale)
a . This method computes the full real
inverse transform, i.e. you will get the same result as from complexInverse called with all
imaginary part equal 0. Because the result is stored in a, the size of the input array must greater
or equal 2*n, with only the first n elements filled with real data.a - data to transformoffa - index of the first element in array ascale - if true then scaling is performedCopyright © 2019 GSI Helmholtzzentrum für Schwerionenforschung GmbH. All rights reserved.