1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
/* -*- 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 Chris Cannam.
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 SV_LOG_RANGE_H
#define SV_LOG_RANGE_H
#include <vector>
#include "Debug.h"
namespace sv {
class LogRange
{
public:
/**
* Map a value onto a logarithmic range. This just means taking
* the base-10 log of the absolute value, or using the threshold
* value if the absolute value is zero.
*/
static double map(double value, double thresh = -10);
/**
* Map a value from the logarithmic range back again. This just
* means taking the value'th power of ten.
*/
static double unmap(double value);
/**
* Map a linear range onto a logarithmic range. min and max are
* passed as the extents of the linear range and returned as the
* extents of the logarithmic range. thresh is the minimum value
* for the log range, to be used if the linear range spans zero.
*/
static void mapRange(double &min, double &max, double thresh = -10);
/**
* Estimate whether a set of values would be more properly shown
* using a logarithmic than a linear scale. This is only ever
* going to be a rough guess.
*/
static bool shouldUseLogScale(std::vector<double> values);
};
} // end namespace sv
#endif
|