mirror of
https://github.com/boostorg/ublas.git
synced 2026-02-19 02:42:16 +00:00
67 lines
1.6 KiB
C++
67 lines
1.6 KiB
C++
//
|
|
// Copyright (c) 2000-2002
|
|
// Joerg Walter, Mathias Koch
|
|
//
|
|
// Permission to use, copy, modify, distribute and sell this software
|
|
// and its documentation for any purpose is hereby granted without fee,
|
|
// provided that the above copyright notice appear in all copies and
|
|
// that both that copyright notice and this permission notice appear
|
|
// in supporting documentation. The authors make no representations
|
|
// about the suitability of this software for any purpose.
|
|
// It is provided "as is" without express or implied warranty.
|
|
//
|
|
// The authors gratefully acknowledge the support of
|
|
// GeNeSys mbH & Co. KG in producing this work.
|
|
//
|
|
|
|
#ifndef TEST4_H
|
|
#define TEST4_H
|
|
|
|
#define USE_BANDED
|
|
//#define USE_DIAGONAL
|
|
|
|
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) {
|
|
int size1 = m.size1 ();
|
|
int size2 = m.size2 ();
|
|
for (int i = 0; i < size1; ++ i)
|
|
#ifdef USE_BANDED
|
|
for (int j = std::max (i - 1, 0); j < std::min (i + 2, size2); ++ j)
|
|
#endif
|
|
#ifdef USE_DIAGONAL
|
|
for (int j = std::max (i, 0); j < std::min (i + 1, size2); ++ j)
|
|
#endif
|
|
m (i, j) = i * size1 + j + 1.f;
|
|
}
|
|
|
|
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
|
|
|
|
|