std:: gslice_array
From cppreference.net
|
Défini dans l'en-tête
<valarray>
|
||
|
template
<
class
T
>
class gslice_array ; |
||
std::gslice_array
est un modèle auxiliaire utilisé par l'
opérateur d'indice de valarray
avec un argument
std::
gslice
. Il possède une sémantique de référence vers un sous-ensemble du tableau spécifié par l'objet
std::
gslice
.
Table des matières |
Types membres
| Type | Définition |
value_type
|
T
|
Fonctions membres
construit un
gslice_array
(fonction membre publique) |
|
détruit un
gslice_array
(fonction membre publique) |
|
|
assigne le contenu
(fonction membre publique) |
|
|
effectue une opération arithmétique sur le tableau référencé par la tranche générique.
(fonction membre publique) |
Exemple
Exécuter ce code
#include <cassert> #include <cstddef> #include <iomanip> #include <iostream> #include <numeric> #include <valarray> int main() { std::valarray<int> data(32); std::iota(std::begin(data), std::end(data), 0); const std::size_t offset = 1, z = 2, y = 3, x = 4; const std::valarray<std::size_t> sizes{z, y, x}; const std::valarray<std::size_t> strides{15, 5, 1}; const std::gslice gslice = std::gslice(offset, sizes, strides); // Les indices sont générés selon la formule : // index[k] = offset + [0,1,2)*15 + [0,1,2,3)*5 + [0,1,2,3,4)*1 // = offset + inner_product(sizes[k], strides); // où sizes[k] = {[0,z), [0,y), [0,x)}, l'index le plus à droite (x) // variant le plus rapidement. On obtient ainsi l'ensemble d'indices suivant : // index[0] = 1 + 0*15 + 0*5 + 0*1 = 1 // index[1] = 1 + 0*15 + 0*5 + 1*1 = 2 // index[2] = 1 + 0*15 + 0*5 + 2*1 = 3 // index[3] = 1 + 0*15 + 0*5 + 3*1 = 4 // index[4] = 1 + 0*15 + 1*5 + 0*1 = 6 // index[5] = 1 + 0*15 + 1*5 + 1*1 = 7 // index[6] = 1 + 0*15 + 1*5 + 2*1 = 8 // index[7] = 1 + 0*15 + 1*5 + 3*1 = 9 // ... // index[22] = 1 + 1*15 + 2*5 + 2*1 = 28 // index[23] = 1 + 1*15 + 2*5 + 3*1 = 29 const std::valarray<int> indices = data[gslice]; for (unsigned i = 0; i != indices.size(); ++i) std::cout << std::setfill('0') << std::setw(2) << indices[i] << ' '; std::cout << "\nTotal des indices : " << indices.size() << '\n'; assert(indices.size() == x * y * z); data = 0; std::gslice_array<int> gslice_array = data[gslice]; gslice_array = 1; // Cellules correspondant aux indices générés = '1', cellules ignorées = '0'. for (auto i : data) std::cout << i << ' '; std::cout << "\nSomme des uns = " << data.sum() << '\n'; }
Sortie :
01 02 03 04 06 07 08 09 11 12 13 14 16 17 18 19 21 22 23 24 26 27 28 29 Total des indices : 24 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 1 1 1 1 0 0 Somme des uns = 24
Voir aussi
|
proxy vers un sous-ensemble d'un valarray après application d'un slice
(modèle de classe) |
|
|
(C++23)
|
vue de tableau multidimensionnelle non propriétaire
(modèle de classe) |