HanningWindow, HammingWindow, BlackmanWindow の各クラス. このライブラリを登録した際のプログラム: Demo_Window

Dependents:   TrG_FFT_Analyzer Demo_Window TrG_Spectrogram

Hanning.hpp

Committer:
MikamiUitOpen
Date:
2021-05-23
Revision:
0:823e9a4ab223
Child:
1:d8673bf6f89c

File content as of revision 0:823e9a4ab223:

//-------------------------------------------------------------------
//  Hanning 窓による窓掛け
//      ゼロ詰め(zero-padding)の機能を持つ
//
//  2021/05/22, Copyright (c) 2021 MIKAMI, Naoki
//-------------------------------------------------------------------

#ifndef HANNING_WINDOW_HPP
#define HANNING_WINDOW_HPP

#include "WindowBase.hpp"

namespace Mikami
{
    class HanningWindow : public WindowBase
    {
    public:
        // コンストラクタ
        HanningWindow(uint16_t nFft, uint16_t nData)
                : WindowBase(nFft, nData) { Generate(nData); }
        HanningWindow(uint16_t nFft)
                : WindowBase(nFft, nFft) { Generate(nFft); }

    private:
        // 窓関数を生成
        virtual void Generate(uint16_t nData)
        {
            const float PI2L = 6.283185f/(float)nData;
            for (int k=0; k<nData; k++)
                Set(k, 0.5f - 0.5f*cosf(k*PI2L));
        }

        // コピー・コンストラクタおよび代入演算子の禁止のため
        HanningWindow(const HanningWindow& );
        HanningWindow& operator=(const HanningWindow& );
    };
}
#endif  // HANNING_WINDOW_HPP