Mercurial > hg > svcore
annotate base/LogRange.h @ 534:6038cb6fcd30
* Some simple compression for dense 3d models that actually represent
multirate data such as wavelet transform outputs. If a column has
many elements at top or bottom that are the same as those of an
earlier column, store a reference to that one and truncate the
duplicate values.
author | Chris Cannam |
---|---|
date | Fri, 23 Jan 2009 13:31:51 +0000 |
parents | 1405f4a2caf3 |
children | 06f13a3b9e9e |
rev | line source |
---|---|
Chris@224 | 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ |
Chris@224 | 2 |
Chris@224 | 3 /* |
Chris@224 | 4 Sonic Visualiser |
Chris@224 | 5 An audio file viewer and annotation editor. |
Chris@224 | 6 Centre for Digital Music, Queen Mary, University of London. |
Chris@224 | 7 This file copyright 2006 Chris Cannam. |
Chris@224 | 8 |
Chris@224 | 9 This program is free software; you can redistribute it and/or |
Chris@224 | 10 modify it under the terms of the GNU General Public License as |
Chris@224 | 11 published by the Free Software Foundation; either version 2 of the |
Chris@224 | 12 License, or (at your option) any later version. See the file |
Chris@224 | 13 COPYING included with this distribution for more information. |
Chris@224 | 14 */ |
Chris@224 | 15 |
Chris@224 | 16 #ifndef _LOG_RANGE_H_ |
Chris@224 | 17 #define _LOG_RANGE_H_ |
Chris@224 | 18 |
Chris@478 | 19 #include <vector> |
Chris@478 | 20 |
Chris@224 | 21 class LogRange |
Chris@224 | 22 { |
Chris@224 | 23 public: |
Chris@224 | 24 /** |
Chris@224 | 25 * Map a linear range onto a logarithmic range. min and max are |
Chris@224 | 26 * passed as the extents of the linear range and returned as the |
Chris@224 | 27 * extents of the logarithmic range. thresh is the minimum value |
Chris@224 | 28 * for the log range, to be used if the linear range spans zero. |
Chris@224 | 29 */ |
Chris@224 | 30 static void mapRange(float &min, float &max, float thresh = -10); |
Chris@224 | 31 |
Chris@224 | 32 /** |
Chris@224 | 33 * Map a value onto a logarithmic range. This just means taking |
Chris@224 | 34 * the base-10 log of the absolute value, or using the threshold |
Chris@224 | 35 * value if the absolute value is zero. |
Chris@224 | 36 */ |
Chris@224 | 37 static float map(float value, float thresh = -10); |
Chris@266 | 38 |
Chris@266 | 39 /** |
Chris@266 | 40 * Map a value from the logarithmic range back again. This just |
Chris@266 | 41 * means taking the value'th power of ten. |
Chris@266 | 42 */ |
Chris@266 | 43 static float unmap(float value); |
Chris@478 | 44 |
Chris@478 | 45 /** |
Chris@478 | 46 * Estimate whether a set of values would be more properly shown |
Chris@478 | 47 * using a logarithmic than a linear scale. This is only ever |
Chris@478 | 48 * going to be a rough guess. |
Chris@478 | 49 */ |
Chris@478 | 50 static bool useLogScale(std::vector<float> values); |
Chris@478 | 51 |
Chris@224 | 52 }; |
Chris@224 | 53 |
Chris@224 | 54 #endif |