mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 22:18:23 +01:00
47cb8a03f7
- Simplify group_indices - Only for C ordered, remove complex compile time. - Could be generalized to non C ordered, but no need. - Fix slice for custom orders. - Generalize the group_indices for the custom order. - Add c_ordered_transposed_view (useful ?) - Improve slice, special for ellipsis (quicker). - Simplify TraversalOrder - Assignement. Specialize one case for speed. - use FORCEINLINE in foreach, according to speed test for clang - add one speed test - Modify iterators for better speed. - along the lines decided for the foreach - update doc.
58 lines
4.9 KiB
ReStructuredText
58 lines
4.9 KiB
ReStructuredText
.. highlight:: c
|
|
|
|
.. _arr_view_constr:
|
|
|
|
Constructors of views
|
|
================================
|
|
|
|
Note that in practice, you rarely explicitly construct a view.
|
|
Views are normally automatically built by the :ref:`() operator<arr_call>`.
|
|
|
|
Constructors of array_view
|
|
---------------------------------------
|
|
|
|
Views have `view semantics`, i.e. they **never** make a copy of the data.
|
|
|
|
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
| Constructors of array_view | Comments |
|
|
+===================================+=======================================================================================+
|
|
| array_view(const array_view &) | Copy construction: create a new view, viewing the same data. Does **not** copy data |
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
| array_view(const T & X) | T is any type such that X.indexmap() and X.storage() can be used to construct a view. |
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
| array_view(array_view &&) | Move construction (trivial here, a copy constructor is very quick anyway). |
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
| explicit array_view(PyObject * X) | Construct an array_view from the Python object X. Type and rank must match exactly, |
|
|
| | or an exception if thrown |
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
| | .. note:: X is a borrowed reference, array does not affect its counting reference. |
|
|
+-----------------------------------+---------------------------------------------------------------------------------------+
|
|
|
|
|
|
Constructors of array_const_view
|
|
---------------------------------------
|
|
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| Constructors of array_const_view<T,R,TraversalOrder> | Comments |
|
|
+========================================================================+=======================================================================================+
|
|
| array_const_view(array_const_view const &) | Create a new view, viewing the same data. Does **not** copy data. (copy constructor) |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| array_const_view(array_view<T,R,OptionsFlags, TraversalOrder> const &) | Create a new view, viewing the same data. Does **not** copy data |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| array_const_view(const T & X) | T is any type such that X.indexmap() and X.storage() can be used to construct a view. |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| array_const_view(array_const_view &&) | Move construction (trivial here, a copy constructor is very quick anyway). |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| explicit array_const_view(PyObject * X) | Construct an array_view from the Python object X. Type and rank must match exactly, |
|
|
| | or an exception if thrown |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
| | .. note:: X is a borrowed reference, array does not affect its counting reference. |
|
|
+------------------------------------------------------------------------+---------------------------------------------------------------------------------------+
|
|
|
|
|
|
Constructors of matrix_view, vector_view, matrix_const_view, vector_const_view
|
|
-------------------------------------------------------------------------------
|
|
|
|
Similar to array_view, array_const_view
|