Namespaces
Variants

std:: gslice

From cppreference.net
ヘッダーで定義 <valarray>
class gslice ;

std::gslice は、複数レベルのストライドとサイズのセットによって定義される std::valarray のインデックスサブセットを識別するセレクタクラスです。 std::gslice 型のオブジェクトは、valarrayの operator [ ] と共にインデックスとして使用でき、例えば valarray として表現された多次元配列の列を選択するために利用できます。

開始値 s 、ストライドのリスト i j 、およびサイズのリスト d j が与えられたとき、これらの値から構築された std::gslice は、インデックスの集合 k j =s+Σ j (i j d j ) を選択します。

例えば、開始インデックス 3 、ストライド {19,4,1 }、長さ {2,4,3 }のgsliceは、以下の 24=2*4*3 個のインデックス集合を生成します:

3 + 0 * 19 + 0 * 4 + 0 * 1 = 3
3 + 0 * 19 + 0 * 4 + 1 * 1 = 4
3 + 0 * 19 + 0 * 4 + 2 * 1 = 5
3 + 0 * 19 + 1 * 4 + 0 * 1 = 7
3 + 0 * 19 + 1 * 4 + 1 * 1 = 8
3 + 0 * 19 + 1 * 4 + 2 * 1 = 9
3 + 0 * 19 + 2 * 4 + 0 * 1 = 11
...
3 + 1 * 19 + 3 * 4 + 1 * 1 = 35
3 + 1 * 19 + 3 * 4 + 2 * 1 = 36

【翻訳説明】 - 数式部分はC++コードとして扱われているため、数値と演算子はすべて原文のまま保持 - カンマ「,」を日本語の読点「、」に変換 - HTMLタグと属性は完全に保持 - 数式の構造とフォーマットは完全に維持

同じインデックスを複数回選択する std::gslice オブジェクトを構築することが可能です:上記の例でストライドを {1,1,1} にした場合、インデックスは {3, 4, 5, 4, 5, 6, ...} のようになります。このようなgsliceは std::valarray::operator[] のconst版への引数としてのみ使用できます。それ以外の場合の動作は未定義です。

目次

メンバー関数

(constructor)
ジェネリックスライスを構築する
(public member function)
start size stride
スライスのパラメータを返す
(public member function)

std::gslice:: gslice

gslice ( )
(1)
gslice ( std:: size_t start, const std:: valarray < std:: size_t > & sizes,
const std:: valarray < std:: size_t > & strides ) ;
(2)
gslice ( const gslice & other ) ;
(3)

新たな汎用スライスを構築します。

1) デフォルトコンストラクタ。 gslice ( 0 , std:: valarray < std:: size_t > ( ) , std:: valarray < std:: size_t > ( ) ) と同等です。このコンストラクタはスライスの配列を構築するためにのみ存在します。
2) パラメータ start , sizes , strides で新たなスライスを構築します。
3) other のコピーを構築します。

パラメータ

start - 最初の要素の位置
sizes - 各次元の要素数を定義する配列
strides - 各次元における連続する要素間の位置数を定義する配列
other - コピーする別のスライス


std::slice:: start, size, stride

std:: size_t start ( ) const ;
(1)
std:: valarray < std:: size_t > size ( ) const ;
(2)
std:: valarray < std:: size_t > stride ( ) const ;
(3)

スライスの構築時に渡されたパラメータ - それぞれ開始位置、サイズ、ストライドを返します。

パラメータ

(なし)

戻り値

スライスのパラメータ - それぞれ開始位置、サイズ、ストライド。

計算量

定数時間。

3次元配列の列をアドレス指定するためのgsliceの使用法を示します:

#include <iostream>
#include <valarray>
void test_print(std::valarray<int>& v, int planes, int rows, int cols)
{
    for (int r = 0; r < rows; ++r)
    {
        for (int z = 0; z < planes; ++z)
        {
            for (int c = 0; c < cols; ++c)
                std::cout << v[z * rows * cols + r * cols + c] << ' ';
            std::cout << "  ";
        }
        std::cout << '\n';
    }
}
int main()
{
    std::valarray<int> v = // 3d array: 2 x 4 x 3 elements
        {111,112,113 , 121,122,123 , 131,132,133 , 141,142,143,
         211,212,213 , 221,222,223 , 231,232,233 , 241,242,243};
    // int ar3d[2][4][3]
    std::cout << "Initial 2x4x3 array:\n";
    test_print(v, 2, 4, 3);
    // update every value in the first columns of both planes
    v[std::gslice(0, {2, 4}, {4 * 3, 3})] = 1; // two level one strides of 12 elements
                                               // then four level two strides of 3 elements
    // subtract the third column from the second column in the 1st plane
    v[std::gslice(1, {1, 4}, {4 * 3, 3})] -= v[std::gslice(2, {1, 4}, {4 * 3, 3})];
    std::cout << "\n" "After column operations:\n";
    test_print(v, 2, 4, 3);
}

出力:

Initial 2x4x3 array:
111 112 113   211 212 213
121 122 123   221 222 223
131 132 133   231 232 233
141 142 143   241 242 243
After column operations:
1 -1 113   1 212 213
1 -1 123   1 222 223
1 -1 133   1 232 233
1 -1 143   1 242 243

不具合報告

以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。

DR Applied to Behavior as published Correct behavior
LWG 543 C++98 デフォルト構築されたジェネリックスライスが使用可能か不明確であった 使用可能(空のサブセットとして)

関連項目

valarrayの要素、スライス、またはマスクの取得/設定
(公開メンバ関数)
BLASライクなvalarrayのスライス:開始インデックス、長さ、ストライド
(クラス)
gslice適用後のvalarrayの部分集合へのプロキシ
(クラステンプレート)