annotate data/fileio/MatrixFile.h @ 1103:e86a7ea3dc38 simple-fft-model

Fix a cache-related dumbitude
author Chris Cannam
date Tue, 16 Jun 2015 20:28:23 +0100
parents 59e7fe1b1003
children aa588c391d1a
rev   line source
Chris@148 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@148 2
Chris@148 3 /*
Chris@148 4 Sonic Visualiser
Chris@148 5 An audio file viewer and annotation editor.
Chris@148 6 Centre for Digital Music, Queen Mary, University of London.
Chris@537 7 This file copyright 2006-2009 Chris Cannam and QMUL.
Chris@148 8
Chris@148 9 This program is free software; you can redistribute it and/or
Chris@148 10 modify it under the terms of the GNU General Public License as
Chris@148 11 published by the Free Software Foundation; either version 2 of the
Chris@148 12 License, or (at your option) any later version. See the file
Chris@148 13 COPYING included with this distribution for more information.
Chris@148 14 */
Chris@148 15
Chris@148 16 #ifndef _MATRIX_FILE_CACHE_H_
Chris@148 17 #define _MATRIX_FILE_CACHE_H_
Chris@148 18
Chris@148 19 #include "base/ResizeableBitset.h"
Chris@148 20
Chris@148 21 #include "FileReadThread.h"
Chris@148 22
Chris@148 23 #include <sys/types.h>
Chris@148 24 #include <QString>
Chris@148 25 #include <QMutex>
Chris@148 26 #include <map>
Chris@148 27
Chris@148 28 class MatrixFile : public QObject
Chris@148 29 {
Chris@148 30 Q_OBJECT
Chris@148 31
Chris@148 32 public:
Chris@537 33 enum Mode { ReadOnly, WriteOnly };
Chris@148 34
Chris@148 35 /**
Chris@148 36 * Construct a MatrixFile object reading from and/or writing to
Chris@148 37 * the matrix file with the given base name in the application's
Chris@148 38 * temporary directory.
Chris@148 39 *
Chris@148 40 * If mode is ReadOnly, the file must exist and be readable.
Chris@148 41 *
Chris@537 42 * If mode is WriteOnly, the file must not exist.
Chris@148 43 *
Chris@148 44 * cellSize specifies the size in bytes of the object type stored
Chris@148 45 * in the matrix. For example, use cellSize = sizeof(float) for a
Chris@148 46 * matrix of floats. The MatrixFile object doesn't care about the
Chris@148 47 * objects themselves, it just deals with raw data of a given size.
Chris@148 48 *
Chris@537 49 * width and height specify the dimensions of the file. These
Chris@537 50 * cannot be changed after construction.
Chris@537 51 *
Chris@537 52 * MatrixFiles are reference counted by name. When the last
Chris@537 53 * MatrixFile with a given name is destroyed, the file is removed.
Chris@537 54 * These are temporary files; the normal usage is to have one
Chris@537 55 * MatrixFile of WriteOnly type creating the file and then
Chris@537 56 * persisting until all readers are complete.
Chris@537 57 *
Chris@537 58 * MatrixFile has no built-in cache and is not thread-safe. Use a
Chris@537 59 * separate MatrixFile in each thread.
Chris@148 60 */
Chris@929 61 MatrixFile(QString fileBase, Mode mode, int cellSize,
Chris@929 62 int width, int height);
Chris@148 63 virtual ~MatrixFile();
Chris@148 64
Chris@148 65 Mode getMode() const { return m_mode; }
Chris@148 66
Chris@929 67 int getWidth() const { return m_width; }
Chris@929 68 int getHeight() const { return m_height; }
Chris@929 69 int getCellSize() const { return m_cellSize; }
Chris@550 70
Chris@550 71 /**
Chris@550 72 * If this is set true on a write-mode MatrixFile, then the file
Chris@550 73 * will close() itself when all columns have been written.
Chris@550 74 */
Chris@550 75 void setAutoClose(bool a) { m_autoClose = a; }
Chris@550 76
Chris@537 77 void close(); // does not decrement ref count; that happens in dtor
Chris@148 78
Chris@929 79 bool haveSetColumnAt(int x) const;
Chris@929 80 void getColumnAt(int x, void *data); // may throw FileReadFailed
Chris@929 81 void setColumnAt(int x, const void *data);
Chris@148 82
Chris@148 83 protected:
Chris@148 84 int m_fd;
Chris@148 85 Mode m_mode;
Chris@148 86 int m_flags;
Chris@148 87 mode_t m_fmode;
Chris@929 88 int m_cellSize;
Chris@929 89 int m_width;
Chris@929 90 int m_height;
Chris@929 91 int m_headerSize;
Chris@148 92 QString m_fileName;
Chris@148 93
Chris@550 94 ResizeableBitset *m_setColumns; // only in writer
Chris@550 95 bool m_autoClose;
Chris@550 96
Chris@554 97 // In reader: if this is >= 0, we can read that column directly
Chris@554 98 // without seeking (and we know that the column exists)
Chris@554 99 mutable int m_readyToReadColumn;
Chris@554 100
Chris@148 101 static std::map<QString, int> m_refcount;
Chris@537 102 static QMutex m_createMutex;
Chris@148 103
Chris@537 104 void initialise();
Chris@929 105 bool seekTo(int col) const;
Chris@148 106 };
Chris@148 107
Chris@148 108 #endif
Chris@148 109