annotate data/fft/FFTFileCache.h @ 282:d9319859a4cf tip

(none)
author benoitrigolleau
date Fri, 31 Oct 2008 11:00:24 +0000
parents fc9323a41f5a
children
rev   line source
lbajardsilogic@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
lbajardsilogic@0 2
lbajardsilogic@0 3 /*
lbajardsilogic@0 4 Sonic Visualiser
lbajardsilogic@0 5 An audio file viewer and annotation editor.
lbajardsilogic@0 6 Centre for Digital Music, Queen Mary, University of London.
lbajardsilogic@0 7 This file copyright 2006 Chris Cannam and QMUL.
lbajardsilogic@0 8
lbajardsilogic@0 9 This program is free software; you can redistribute it and/or
lbajardsilogic@0 10 modify it under the terms of the GNU General Public License as
lbajardsilogic@0 11 published by the Free Software Foundation; either version 2 of the
lbajardsilogic@0 12 License, or (at your option) any later version. See the file
lbajardsilogic@0 13 COPYING included with this distribution for more information.
lbajardsilogic@0 14 */
lbajardsilogic@0 15
lbajardsilogic@0 16 #ifndef _FFT_FILE_CACHE_H_
lbajardsilogic@0 17 #define _FFT_FILE_CACHE_H_
lbajardsilogic@0 18
lbajardsilogic@0 19 #include "FFTCache.h"
lbajardsilogic@0 20 #include "fileio/MatrixFile.h"
lbajardsilogic@0 21
lbajardsilogic@0 22 #include <QMutex>
lbajardsilogic@0 23
lbajardsilogic@0 24 class FFTFileCache : public FFTCache
lbajardsilogic@0 25 {
lbajardsilogic@0 26 public:
lbajardsilogic@0 27 enum StorageType {
lbajardsilogic@0 28 Compact, // 16 bits normalized polar
lbajardsilogic@0 29 Rectangular, // floating point real+imag
lbajardsilogic@0 30 Polar, // floating point mag+phase
lbajardsilogic@0 31 };
lbajardsilogic@0 32
lbajardsilogic@0 33 FFTFileCache(QString fileBase, MatrixFile::Mode mode,
lbajardsilogic@0 34 StorageType storageType);
lbajardsilogic@0 35 virtual ~FFTFileCache();
lbajardsilogic@0 36
lbajardsilogic@0 37 MatrixFile::Mode getMode() const { return m_mfc->getMode(); }
lbajardsilogic@0 38
lbajardsilogic@0 39 virtual size_t getWidth() const;
lbajardsilogic@0 40 virtual size_t getHeight() const;
lbajardsilogic@0 41
lbajardsilogic@0 42 virtual void resize(size_t width, size_t height);
lbajardsilogic@0 43 virtual void reset(); // zero-fill or 1-fill as appropriate without changing size
lbajardsilogic@0 44
lbajardsilogic@0 45 virtual float getMagnitudeAt(size_t x, size_t y) const;
lbajardsilogic@0 46 virtual float getNormalizedMagnitudeAt(size_t x, size_t y) const;
lbajardsilogic@0 47 virtual float getMaximumMagnitudeAt(size_t x) const;
lbajardsilogic@0 48 virtual float getPhaseAt(size_t x, size_t y) const;
lbajardsilogic@0 49
lbajardsilogic@0 50 virtual void getValuesAt(size_t x, size_t y, float &real, float &imag) const;
lbajardsilogic@0 51
lbajardsilogic@0 52 virtual bool haveSetColumnAt(size_t x) const;
lbajardsilogic@0 53
lbajardsilogic@0 54 virtual void setColumnAt(size_t x, float *mags, float *phases, float factor);
lbajardsilogic@0 55 virtual void setColumnAt(size_t x, float *reals, float *imags);
lbajardsilogic@0 56
lbajardsilogic@0 57 virtual void suspend() { m_mfc->suspend(); }
lbajardsilogic@0 58
lbajardsilogic@0 59 static size_t getCacheSize(size_t width, size_t height, StorageType type);
lbajardsilogic@0 60
lbajardsilogic@0 61 protected:
lbajardsilogic@0 62 char *m_writebuf;
lbajardsilogic@0 63 mutable char *m_readbuf;
lbajardsilogic@0 64 mutable size_t m_readbufCol;
lbajardsilogic@0 65 mutable size_t m_readbufWidth;
lbajardsilogic@0 66
lbajardsilogic@0 67 float getFromReadBufStandard(size_t x, size_t y) const {
lbajardsilogic@0 68 if (m_readbuf &&
lbajardsilogic@0 69 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
lbajardsilogic@0 70 return ((float *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
lbajardsilogic@0 71 } else {
lbajardsilogic@0 72 populateReadBuf(x);
lbajardsilogic@0 73 return getFromReadBufStandard(x, y);
lbajardsilogic@0 74 }
lbajardsilogic@0 75 }
lbajardsilogic@0 76
lbajardsilogic@0 77 float getFromReadBufCompactUnsigned(size_t x, size_t y) const {
lbajardsilogic@0 78 if (m_readbuf &&
lbajardsilogic@0 79 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
lbajardsilogic@0 80 return ((uint16_t *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
lbajardsilogic@0 81 } else {
lbajardsilogic@0 82 populateReadBuf(x);
lbajardsilogic@0 83 return getFromReadBufCompactUnsigned(x, y);
lbajardsilogic@0 84 }
lbajardsilogic@0 85 }
lbajardsilogic@0 86
lbajardsilogic@0 87 float getFromReadBufCompactSigned(size_t x, size_t y) const {
lbajardsilogic@0 88 if (m_readbuf &&
lbajardsilogic@0 89 (m_readbufCol == x || (m_readbufWidth > 1 && m_readbufCol+1 == x))) {
lbajardsilogic@0 90 return ((int16_t *)m_readbuf)[(x - m_readbufCol) * m_mfc->getHeight() + y];
lbajardsilogic@0 91 } else {
lbajardsilogic@0 92 populateReadBuf(x);
lbajardsilogic@0 93 return getFromReadBufCompactSigned(x, y);
lbajardsilogic@0 94 }
lbajardsilogic@0 95 }
lbajardsilogic@0 96
lbajardsilogic@0 97 void populateReadBuf(size_t x) const;
lbajardsilogic@0 98
lbajardsilogic@0 99 float getNormalizationFactor(size_t col) const {
lbajardsilogic@0 100 if (m_storageType != Compact) {
lbajardsilogic@0 101 return getFromReadBufStandard(col, m_mfc->getHeight() - 1);
lbajardsilogic@0 102 } else {
lbajardsilogic@0 103 float factor;
lbajardsilogic@0 104 factor = getFromReadBufCompactUnsigned(col, m_mfc->getHeight() - 1);
lbajardsilogic@0 105 return factor / 65535.0;
lbajardsilogic@0 106 }
lbajardsilogic@0 107 }
lbajardsilogic@0 108
lbajardsilogic@0 109 MatrixFile *m_mfc;
lbajardsilogic@0 110 QMutex m_writeMutex;
lbajardsilogic@0 111 StorageType m_storageType;
lbajardsilogic@0 112 };
lbajardsilogic@0 113
lbajardsilogic@0 114 #endif