mirror of
https://github.com/boostorg/ublas.git
synced 2026-02-10 11:52:21 +00:00
38 lines
1.4 KiB
C++
38 lines
1.4 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.
|
|
//
|
|
|
|
#include <boost/numeric/ublas/hermitian.hpp>
|
|
#include <boost/numeric/ublas/io.hpp>
|
|
|
|
int main () {
|
|
using namespace boost::numeric::ublas;
|
|
hermitian_matrix<std::complex<double>, lower> ml (3, 3);
|
|
for (unsigned i = 0; i < ml.size1 (); ++ i) {
|
|
for (unsigned j = 0; j < i; ++ j)
|
|
ml (i, j) = std::complex<double> (3 * i + j, 3 * i + j);
|
|
ml (i, i) = std::complex<double> (4 * i, 0);
|
|
}
|
|
std::cout << ml << std::endl;
|
|
hermitian_matrix<std::complex<double>, upper> mu (3, 3);
|
|
for (unsigned i = 0; i < mu.size1 (); ++ i) {
|
|
mu (i, i) = std::complex<double> (4 * i, 0);
|
|
for (unsigned j = i + 1; j < mu.size2 (); ++ j)
|
|
mu (i, j) = std::complex<double> (3 * i + j, 3 * i + j);
|
|
}
|
|
std::cout << mu << std::endl;
|
|
}
|
|
|