[4b93a6]: libkwave / Matrix.h Maximize Restore History

Download this file

Matrix.h    71 lines (55 with data), 1.9 kB

 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
60
61
62
63
64
65
66
67
68
69
70
/***************************************************************************
Matrix.h - simple template class for a NxM matrix
-------------------
begin : Sat May 12 2012
copyright : (C) 2012 by Thomas Eschenbacher
email : Thomas.Eschenbacher@gmx.de
based on Matrix.h from Martin Hinsch
copyright (C) 2001 by Martin Hinsch <vidas@sourceforge.net>
***************************************************************************/
/***************************************************************************
* *
* 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. *
* *
***************************************************************************/
#ifndef _MATRIX_H_
#define _MATRIX_H_
#include "config.h"
#include <QtGlobal>
namespace Kwave {
template <class T> class Matrix
{
public:
/**
* constructor
* @param cols number of columns
* @param rows number of rows
*/
Matrix(unsigned int cols, unsigned int rows)
:m_rows(rows), m_cols(cols), m_data(0)
{
m_data = new T[m_rows * m_cols];
Q_ASSERT(m_data);
}
/** destructor */
virtual ~Matrix()
{
if (m_data) delete[] m_data;
}
/** Get the xth column. Enables expressions like myMatrix[x][y]. */
inline T * operator[] (unsigned int col) const {
return m_data + (col * m_rows);
}
private:
/** number of rows */
unsigned int m_rows;
/** number of columns */
unsigned int m_cols;
/** raw data */
T *m_data;
};
}
#endif /* _MATRIX_H_ */