mirror of
https://github.com/triqs/dft_tools
synced 2025-01-14 06:45:59 +01:00
f2c7d449cc
for earlier commits, see TRIQS0.x repository.
34 lines
1.2 KiB
ReStructuredText
34 lines
1.2 KiB
ReStructuredText
Why several classes ?
|
|
=================================================================
|
|
|
|
The library provides several interoperable forms of arrays : array, matrix and vector.
|
|
|
|
.. note:: Why several classes ?
|
|
|
|
Because their algebra differ, e.g. a matrix<T> is not really a array<T,2> :
|
|
the multiplication for a matrix is the matrix multiplication, while it is element wise for the array.
|
|
|
|
|
|
Interoperability
|
|
---------------------------------------------------
|
|
|
|
* These classes are largely similar, and are interoperable.
|
|
|
|
* One can construct a matrix_view from a array, e.g. (providing the rank of the array is 2, of course...).
|
|
|
|
* Why several classes then ? The reason is that their algebra (i.e. their behaviour under operations) differ.
|
|
|
|
For example, a matrix<T> is not really a array<T,2> :
|
|
the multiplication for a matrix is the matrix multiplication, while it is element wise for the array.
|
|
The expression template implements two different algebras, one for arrays, one for matrices and vectors.
|
|
|
|
TODO : write the example and code the make_matrix_view function....
|
|
|
|
Example::
|
|
|
|
array<double,3> A; matrix<double> M;
|
|
auto res = matrix_view<double> ( A(0,range(),range()) ) + M;
|
|
|
|
|
|
|