Spectrum Example▲
Sélectionnez
/**
***************************************************************************
FFTRealFixLen.h
Copyright (c) 2005 Laurent de Soras
--- Legal stuff ---
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*Tab=3**********************************************************************
*/
#if ! defined (FFTRealFixLen_HEADER_INCLUDED)
#define FFTRealFixLen_HEADER_INCLUDED
#if defined (_MSC_VER)
#pragma once
#pragma warning (4 : 4250)
// "Inherits via dominance."
#endif
/*\\\ INCLUDE FILES \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/
#include
"Array.h"
#include
"DynArray.h"
#include
"FFTRealFixLenParam.h"
#include
"OscSinCos.h"
template
&
lt;int
LL2&
gt;
class
FFTRealFixLen
{
typedef
int
CompileTimeCheck1 [(LL2 &
gt;=
0
) ? 1
: -
1
];
typedef
int
CompileTimeCheck2 [(LL2 &
lt;=
30
) ? 1
: -
1
];
/*\\\ PUBLIC \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/
public
:
typedef
FFTRealFixLenParam::
DataType DataType;
typedef
OscSinCos &
lt;DataType&
gt; OscType;
enum
{
FFT_LEN_L2 =
LL2 }
;
enum
{
FFT_LEN =
1
&
lt;&
lt; FFT_LEN_L2 }
;
FFTRealFixLen ();
inline
long
get_length () const
;
void
do_fft (DataType f [], const
DataType x []);
void
do_ifft (const
DataType f [], DataType x []);
void
rescale (DataType x []) const
;
/*\\\ PROTECTED \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/
protected
:
/*\\\ PRIVATE \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/
private
:
enum
{
TRIGO_BD_LIMIT =
FFTRealFixLenParam::
TRIGO_BD_LIMIT }
;
enum
{
BR_ARR_SIZE_L2 =
((FFT_LEN_L2 -
3
) &
lt; 0
) ? 0
: (FFT_LEN_L2 -
2
) }
;
enum
{
BR_ARR_SIZE =
1
&
lt;&
lt; BR_ARR_SIZE_L2 }
;
enum
{
TRIGO_BD =
((FFT_LEN_L2 -
TRIGO_BD_LIMIT) &
lt; 0
)
? (int
)FFT_LEN_L2
:
(int
)TRIGO_BD_LIMIT }
;
enum
{
TRIGO_TABLE_ARR_SIZE_L2 =
(LL2 &
lt; 4
) ? 0
: (TRIGO_BD -
2
) }
;
enum
{
TRIGO_TABLE_ARR_SIZE =
1
&
lt;&
lt; TRIGO_TABLE_ARR_SIZE_L2 }
;
enum
{
NBR_TRIGO_OSC =
FFT_LEN_L2 -
TRIGO_BD }
;
enum
{
TRIGO_OSC_ARR_SIZE =
(NBR_TRIGO_OSC &
gt; 0
) ? NBR_TRIGO_OSC : 1
}
;
void
build_br_lut ();
void
build_trigo_lut ();
void
build_trigo_osc ();
DynArray &
lt;DataType&
gt;
_buffer;
DynArray &
lt;long
&
gt;
_br_data;
DynArray &
lt;DataType&
gt;
_trigo_data;
Array &
lt;OscType, TRIGO_OSC_ARR_SIZE&
gt;
_trigo_osc;
/*\\\ FORBIDDEN MEMBER FUNCTIONS \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/
private
:
FFTRealFixLen (const
FFTRealFixLen &
amp;other);
FFTRealFixLen&
amp; operator
=
(const
FFTRealFixLen &
amp;other);
bool
operator
==
(const
FFTRealFixLen &
amp;other);
bool
operator
!=
(const
FFTRealFixLen &
amp;other);
}
; // class FFTRealFixLen
#include
"FFTRealFixLen.hpp"
#endif
// FFTRealFixLen_HEADER_INCLUDED
/*\\\ EOF \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\*/