///////////////////////////////////////////////////////////////////////////////////
// Copyright (C) 2016 F4EXB                                                      //
// written by Edouard Griffiths                                                  //
//                                                                               //
// This program is free software; you can redistribute it and/or modify          //
// it under the terms of the GNU General Public License as published by          //
// the Free Software Foundation as version 3 of the License, or                  //
//                                                                               //
// This program 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 General Public License V3 for more details.                               //
//                                                                               //
// You should have received a copy of the GNU General Public License             //
// along with this program. If not, see .          //
///////////////////////////////////////////////////////////////////////////////////
#ifndef SDRBASE_DSP_HBFILTERTRAITS_H_
#define SDRBASE_DSP_HBFILTERTRAITS_H_
#include 
#include "export.h"
// uses Q1.14 format internally, input and output are S16
/*
 * supported filter orders: 96, 80, 64, 48, 32
 * any usage of another value will be prevented by compilation errors
 */
template
struct HBFIRFilterTraits
{
};
template<>
struct SDRBASE_API HBFIRFilterTraits<16>
{
    static const int32_t hbOrder = 16;
    static const int32_t hbShift = 12;
    static const int16_t hbMod[16+6];
    static const int32_t hbCoeffs[4] __attribute__ ((aligned (16)));
    static const double  hbCoeffsF[4];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<32>
{
    static const int32_t hbOrder = 32;
    static const int32_t hbShift = 12;
    static const int16_t hbMod[32+6];
    static const int32_t hbCoeffs[8] __attribute__ ((aligned (32)));
    static const double  hbCoeffsF[8];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<48>
{
    static const int32_t hbOrder = 48;
    static const int32_t hbShift = 12;
    static const int16_t hbMod[48+6];
    static const int32_t hbCoeffs[12] __attribute__ ((aligned (16)));
    static const double  hbCoeffsF[12];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<64>
{
    static const int32_t hbOrder = 64;
    static const int32_t hbShift = 12;
    static const int16_t hbMod[64+6];
    static const int32_t hbCoeffs[16] __attribute__ ((aligned (32)));
    static const double  hbCoeffsF[16];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<80>
{
    static const int32_t hbOrder = 80;
    static const int32_t hbShift = 14;
    static const int16_t hbMod[80+6];
    static const int32_t hbCoeffs[20] __attribute__ ((aligned (16)));
    static const double  hbCoeffsF[20];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<96>
{
    static const int32_t hbOrder = 96;
    static const int32_t hbShift = 16;
    static const int16_t hbMod[96+6];
    static const int32_t hbCoeffs[24] __attribute__ ((aligned (32)));
    static const double  hbCoeffsF[24];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<112>
{
    static const int32_t hbOrder = 112;
    static const int32_t hbShift = 18;
    static const int16_t hbMod[112+6];
    static const int32_t hbCoeffs[28] __attribute__ ((aligned (16)));
    static const double  hbCoeffsF[28];
};
template<>
struct SDRBASE_API HBFIRFilterTraits<128>
{
    static const int32_t hbOrder = 128;
    static const int32_t hbShift = 20;
    static const int16_t hbMod[128+6];
    static const int32_t hbCoeffs[32] __attribute__ ((aligned (16)));
    static const double  hbCoeffsF[32];
};
#endif /* SDRBASE_DSP_HBFILTERTRAITS_H_ */