mirror of
https://github.com/boostorg/ublas.git
synced 2026-02-23 16:12:09 +00:00
68 lines
1.4 KiB
C++
68 lines
1.4 KiB
C++
#ifndef TEST5_H
|
|
#define TEST5_H
|
|
|
|
namespace ublas = boost::numeric::ublas;
|
|
|
|
template<class V>
|
|
void initialize_vector (V &v) {
|
|
int size = v.size ();
|
|
for (int i = 0; i < size; ++ i)
|
|
v [i] = i + 1.f;
|
|
}
|
|
|
|
template<class M>
|
|
void initialize_matrix (M &m, ublas::lower_tag) {
|
|
int size1 = m.size1 ();
|
|
// int size2 = m.size2 ();
|
|
for (int i = 0; i < size1; ++ i) {
|
|
int j = 0;
|
|
for (; j <= i; ++ j)
|
|
m (i, j) = i * size1 + j + 1.f;
|
|
// for (; j < size2; ++ j)
|
|
// m (i, j) = 0.f;
|
|
}
|
|
}
|
|
template<class M>
|
|
void initialize_matrix (M &m, ublas::upper_tag) {
|
|
int size1 = m.size1 ();
|
|
int size2 = m.size2 ();
|
|
for (int i = 0; i < size1; ++ i) {
|
|
int j = 0;
|
|
// for (; j < i; ++ j)
|
|
// m (i, j) = 0.f;
|
|
for (; j < size2; ++ j)
|
|
m (i, j) = i * size1 + j + 1.f;
|
|
}
|
|
}
|
|
template<class M>
|
|
void initialize_matrix (M &m) {
|
|
int size1 = m.size1 ();
|
|
int size2 = m.size2 ();
|
|
for (int i = 0; i < size1; ++ i)
|
|
for (int j = 0; j < size2; ++ j)
|
|
m (i, j) = i * size1 + j + 1;
|
|
}
|
|
|
|
|
|
void test_vector ();
|
|
|
|
void test_matrix_vector ();
|
|
|
|
void test_matrix ();
|
|
|
|
// #define USE_FLOAT
|
|
#define USE_DOUBLE
|
|
// #define USE_STD_COMPLEX
|
|
|
|
// #define USE_RANGE
|
|
// #define USE_SLICE
|
|
|
|
// #define USE_BOUNDED_ARRAY
|
|
#define USE_UNBOUNDED_ARRAY
|
|
// #define USE_STD_VECTOR
|
|
|
|
// #define USE_ADAPTOR
|
|
#endif
|
|
|
|
|