view src/CRP.h @ 24:353e88e4ebea

Refactor
author Chris Cannam
date Tue, 29 Sep 2015 16:36:23 +0100
parents 51eb8b1a1910
children 2c913b88b808
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */

#ifndef CRP_H
#define CRP_H

#include "Types.h"

class DCTReduce;

//!!! Downsampling/temporal smoothing not yet implemented

class CRP
{
public:
    struct Parameters {
	int coefficientsToDrop;
	bool applyLogCompression;
        double logFactor;
        double logAddTerm;
        int normP;
	Parameters() :
            coefficientsToDrop(54),
            applyLogCompression(true),
            logFactor(1000.0),
            logAddTerm(1.0),
            normP(2)
        { }
    };
	
    CRP(Parameters params) : m_params(params), m_size(0), m_dctReduce(0) { }
    ~CRP();

    RealBlock process(const RealBlock &in);
    
private:
    Parameters m_params;
    int m_size;
    DCTReduce *m_dctReduce;
};

#endif