-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBlockMatrix.h
44 lines (32 loc) · 887 Bytes
/
BlockMatrix.h
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
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
/*
* File: BlockMatrix.h
* Author: pc
*
* Created on 16 August 2015, 11:46
*/
#ifndef BLOCKMATRIX_H
#define BLOCKMATRIX_H
#include <functional>
template<class T>
class BlockMatrix {
protected:
unsigned int mWidth;
unsigned int mHeight;
unsigned int* mStarts;
unsigned int* mLengths;
T** mRows;
public:
BlockMatrix(T* data, unsigned int width, unsigned int height, double minVal);
BlockMatrix(const BlockMatrix& orig);
T transformAndSum(std::function<T(int)> src, unsigned int row) const;
unsigned int getWidth() const;
unsigned int getHeight() const;
virtual ~BlockMatrix();
private:
};
#endif /* BLOCKMATRIX_H */