2018-01-12 21:47:58 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004 Michael Stevens
|
|
|
|
* Use, modification and distribution are subject to the
|
|
|
|
* Boost Software License, Version 1.0. (See accompanying file
|
|
|
|
* LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Default construct test when possible
|
|
|
|
*/
|
|
|
|
|
|
|
|
template <class E>
|
|
|
|
struct default_construct
|
|
|
|
{
|
2021-10-05 21:37:46 +02:00
|
|
|
static void test() {}
|
|
|
|
};
|
2018-01-12 21:47:58 +01:00
|
|
|
template <class VC>
|
|
|
|
struct default_construct<boost::numeric::ublas::vector_container<VC> >
|
|
|
|
{
|
2021-10-05 21:37:46 +02:00
|
|
|
static void test()
|
|
|
|
{
|
|
|
|
VC default_constuct;
|
|
|
|
initialize_vector(default_constuct);
|
|
|
|
std::cout << "default construct = " << default_constuct << std::endl;
|
|
|
|
}
|
2018-01-12 21:47:58 +01:00
|
|
|
};
|
|
|
|
template <class MC>
|
|
|
|
struct default_construct<boost::numeric::ublas::matrix_container<MC> >
|
|
|
|
{
|
2021-10-05 21:37:46 +02:00
|
|
|
static void test()
|
|
|
|
{
|
|
|
|
MC default_constuct;
|
|
|
|
initialize_vector(default_constuct);
|
|
|
|
std::cout << "default construct = " << default_constuct << std::endl;
|
|
|
|
}
|
2018-01-12 21:47:58 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Initialise test values in vector/matrix
|
|
|
|
*/
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class V>
|
|
|
|
void initialize_vector(V& v)
|
|
|
|
{
|
|
|
|
typename V::size_type size = v.size();
|
|
|
|
for (typename V::size_type i = 0; i < size; ++i)
|
|
|
|
v[i] = typename V::value_type(i + 1.f);
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class M>
|
|
|
|
void initialize_matrix_impl(M& m, ublas::packed_proxy_tag)
|
|
|
|
{
|
|
|
|
typename M::size_type size1 = m.size1();
|
2018-01-12 21:47:58 +01:00
|
|
|
#ifndef BOOST_UBLAS_NO_NESTED_CLASS_RELATION
|
2021-10-05 21:37:46 +02:00
|
|
|
for (typename M::iterator1 i = m.begin1(); i != m.end1(); ++i)
|
|
|
|
for (typename M::iterator2 j = i.begin(); j != i.end(); ++j)
|
|
|
|
*j = typename M::value_type(i.index1() * size1 + j.index2() + 1.f);
|
2018-01-12 21:47:58 +01:00
|
|
|
#else
|
2021-10-05 21:37:46 +02:00
|
|
|
for (typename M::iterator1 i = m.begin1(); i != m.end1(); ++i)
|
|
|
|
for (typename M::iterator2 j = ublas::begin(i, ublas::iterator1_tag()); j != ublas::end(i, ublas::iterator1_tag()); ++j)
|
|
|
|
*j = typename M::value_type(i.index1() * size1 + j.index2() + 1.f);
|
2018-01-12 21:47:58 +01:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class M>
|
|
|
|
void initialize_matrix_impl(M& m, ublas::sparse_proxy_tag)
|
|
|
|
{
|
|
|
|
typename M::size_type size1 = m.size1();
|
|
|
|
typename M::size_type size2 = m.size2();
|
|
|
|
for (typename M::size_type i = 0; i < size1; ++i)
|
|
|
|
for (typename M::size_type j = 0; j < size2; ++j)
|
|
|
|
m(i, j) = typename M::value_type(i * size1 + j + 1.f);
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class M>
|
|
|
|
void initialize_matrix(M& m)
|
|
|
|
{
|
|
|
|
initialize_matrix_impl(m, typename M::storage_category());
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|
|
|
|
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class M>
|
|
|
|
void initialize_matrix(M& m, ublas::lower_tag)
|
|
|
|
{
|
|
|
|
typename M::size_type size1 = m.size1();
|
|
|
|
typename M::size_type size2 = m.size2();
|
|
|
|
for (typename M::size_type i = 0; i < size1; ++i)
|
|
|
|
{
|
|
|
|
typename M::size_type j = 0;
|
|
|
|
for (; j <= i; ++j)
|
|
|
|
m(i, j) = i * size1 + j + 1.f;
|
|
|
|
for (; j < size2; ++j)
|
|
|
|
m(i, j) = 0.f;
|
|
|
|
}
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|
2021-10-05 21:37:46 +02:00
|
|
|
template <class M>
|
|
|
|
void initialize_matrix(M& m, ublas::upper_tag)
|
|
|
|
{
|
|
|
|
typename M::size_type size1 = m.size1();
|
|
|
|
typename M::size_type size2 = m.size2();
|
|
|
|
for (typename M::size_type i = 0; i < size1; ++i)
|
|
|
|
{
|
|
|
|
typename M::size_type j = 0;
|
|
|
|
for (; j < i; ++j)
|
|
|
|
m(i, j) = 0.f;
|
|
|
|
for (; j < size2; ++j)
|
|
|
|
m(i, j) = i * size1 + j + 1.f;
|
|
|
|
}
|
2018-01-12 21:47:58 +01:00
|
|
|
}
|