-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSparseMatrix.h
More file actions
executable file
·59 lines (48 loc) · 1.22 KB
/
SparseMatrix.h
File metadata and controls
executable file
·59 lines (48 loc) · 1.22 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
//
// SparseMatrix.h
//
//
// Created by Ling Zou on 9/19/13.
//
//
#ifndef _SparseMatrix_h
#define _SparseMatrix_h
#include <vector>
/*
* This class serves as an interface between our code and the solver.
* We do not try to implement any additonal functions of sparse matrix.
*
* How it works:
* ColumnEntry stores an entry: column number and its value
* The row number is determined by its position in the vector.
*/
class SparseMatrix
{
public:
SparseMatrix()
{}
~SparseMatrix()
{}
typedef struct
{
int col_number;
double value;
} ColumnEntry;
/*
* Create empty rows for future ColumnEntry to be inserted
*/
void SetRowNumber(unsigned int total_row_number);
/*
* Add an entry at given position (row, col)
*/
void AddEntry(unsigned int row, unsigned int col, double value = 1);
/*
* Insert a SparseMatrix data structure to this SparseMatrix
* To the position, i-th row and j-th column (index from 0)
*/
void Insert(const SparseMatrix & sparse_matrix, unsigned int row, unsigned int col);
const std::vector<std::vector<ColumnEntry> > & getEntryData() const { return EntryData; }
protected:
std::vector<std::vector<ColumnEntry> > EntryData;
};
#endif