view base/RangeMapper.h @ 335:02d2ad95ea52 spectrogram-cache-rejig

* Get storage advice for each cache in an FFT data server. Allows us to be more confident about the actual memory situation and cut over from memory to disc part way through an FFT calculation if necessary. StorageAdviser is now a bit too optimistic though (it's too keen to allocate large numbers of small blocks in memory).
author Chris Cannam
date Tue, 13 Nov 2007 13:54:10 +0000
parents 91fdc752e540
children ca3b91119482
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*-  vi:set ts=8 sts=4 sw=4: */

/*
    Sonic Visualiser
    An audio file viewer and annotation editor.
    Centre for Digital Music, Queen Mary, University of London.
    This file copyright 2006 QMUL.
    
    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; either version 2 of the
    License, or (at your option) any later version.  See the file
    COPYING included with this distribution for more information.
*/

#ifndef _RANGE_MAPPER_H_
#define _RANGE_MAPPER_H_

#include <QString>


class RangeMapper 
{
public:
    virtual ~RangeMapper() { }
    virtual int getPositionForValue(float value) const = 0;
    virtual float getValueForPosition(int position) const = 0;
    virtual QString getUnit() const { return ""; }
};


class LinearRangeMapper : public RangeMapper
{
public:
    LinearRangeMapper(int minpos, int maxpos,
                      float minval, float maxval,
                      QString unit = "");
    
    virtual int getPositionForValue(float value) const;
    virtual float getValueForPosition(int position) const;

    virtual QString getUnit() const { return m_unit; }

protected:
    int m_minpos;
    int m_maxpos;
    float m_minval;
    float m_maxval;
    QString m_unit;
};


class LogRangeMapper : public RangeMapper
{
public:
    LogRangeMapper(int minpos, int maxpos,
                   float ratio, float minlog,
                   QString m_unit = "");

    virtual int getPositionForValue(float value) const;
    virtual float getValueForPosition(int position) const;

    virtual QString getUnit() const { return m_unit; }

protected:
    int m_minpos;
    int m_maxpos;
    float m_ratio;
    float m_minlog;
    float m_maxlog;
    QString m_unit;
};


#endif