liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
//
//  Copyright (c) 2018-2019, Cem Bassoy, cem.bassoy@gmail.com
//
//  Distributed under 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)
//
//  The authors gratefully acknowledge the support of
//  Fraunhofer IOSB, Ettlingen, Germany
//
 
#ifndef BOOST_UBLAS_TENSOR_OSTREAM_HPP
#define BOOST_UBLAS_TENSOR_OSTREAM_HPP
 
#include <ostream>
#include <complex>
 
namespace boost {
namespace numeric {
namespace ublas {
namespace detail {
 
template <class value_type>
void print(std::ostream& out, value_type const& p)
{
    out << p << " ";
}
 
template <class value_type>
void print(std::ostream& out, const std::complex<value_type>& p)
{
    out << std::real(p) << "+" << std::imag(p) << "i ";
}
 
 
template <class size_type, class value_type>
void print(std::ostream& out, size_type r, const value_type* p, const size_type* w, const size_type* n)
{
 
    if(r < 2)
    {
        out << "[ ... " << std::endl;
 
        for(auto row = 0u; row < n[0]; p += w[0], ++row) // iterate over one column
        {
            auto p1 = p;
            for(auto col = 0u; col < n[1]; p1 += w[1], ++col) // iterate over first row
            {
                print(out,*p1);
            }
            if(row < n[0]-1)
                out << "; " << std::endl;
        }
        out << "]";
    }
    else
    {
        out << "cat("<< r+1 <<",..." << std::endl;
        for(auto d = 0u; d < n[r]-1; p += w[r], ++d){
            print(out, r-1, p, w, n);
            out << ",..." << std::endl;
        }
        print(out, r-1, p, w, n);
    }
    if(r>1)
        out << ")";
}
 
////////////////////////////
 
 
}
}
}
}
 
 
namespace boost {
namespace numeric {
namespace ublas {
 
template<class T, class F, class A>
class tensor;
 
template<class T, class F, class A>
class matrix;
 
template<class T, class A>
class vector;
 
}
}
}
 
 
template <class V, class F, class A>
std::ostream& operator << (std::ostream& out, boost::numeric::ublas::tensor<V,F,A> const& t)
{
 
    if(t.extents().is_scalar()){
        out << '[';
        boost::numeric::ublas::detail::print(out,t[0]);
        out << ']';
    }
    else if(t.extents().is_vector()) {
        const auto& cat = t.extents().at(0) > t.extents().at(1) ? ';' : ',';
        out << '[';
        for(auto i = 0u; i < t.size()-1; ++i){
            boost::numeric::ublas::detail::print(out,t[i]);
            out << cat << ' ';
        }
        boost::numeric::ublas::detail::print(out,t[t.size()-1]);
        out << ']';
    }
    else{
        boost::numeric::ublas::detail::print(out, t.rank()-1, t.data(), t.strides().data(), t.extents().data());
    }
    return out;
}
 
 
#endif