Skip to content

Latest commit

 

History

History
86 lines (66 loc) · 2.33 KB

layout_left_padded.md

File metadata and controls

86 lines (66 loc) · 2.33 KB

layout_left_padded

  • mdspan[meta header]
  • class template[meta id-type]
  • std[meta namespace]
  • cpp26[meta cpp]
namespace std {
  template<size_t PaddingValue = dynamic_extent>
  struct layout_left_padded {
    template<class Extents>
    class mapping;
  };
}
  • dynamic_extent[link /reference/span/dynamic_extent.md]
  • Extents[link extents.md]
  • mapping[link layout_left_padded/mapping.md]

概要

layout_left_paddedは、多次元配列ビューmdspanに対して、パディングあり列優先(column major)レイアウトマッピングを表現するポリシークラスである。

全要素が隣接配置されるlayout_leftとは異なり、layout_left_paddedでは最左次元の隣次元(第1次元)ストライド幅stride(1)が最左次元の要素数extent(0)よりも大きい、つまり第1次元においてパディングが挿入される可能性がある。

layout_left_paddedの特殊化は、レイアウトマッピングポリシー要件を満たすトリビアル型である。

メンバ型

名前 説明 対応バージョン
mapping レイアウトマッピング C++26

#include <mdspan>
#include <print>

int main()
{
  double arr[] = {1, 2, 0, 0, 3, 4, 0, 0, 5, 6, 0, 0};
  // 1 3 5
  // 2 4 6
  // - - -
  // - - -

  // 要素数2x3の2次元配列/列優先レイアウト/アライメント4
  using Ext2x3 = std::extents<size_t, 2, 3>
  std::mdspan<double, Ext2x3, std::layout_left_padded<4>> mat{arr};

  for (size_t i = 0; i < mat.extent(0); ++i) {
    for (size_t j = 0; j < mat.extent(1); ++j) {
      std::print("{}{}", (j ? " " : ""), mat[i, j]);
    }
    std::println();
  }
}
  • std::layout_left_padded[color ff0000]
  • extent[link mdspan/extent.md]

出力

1 3 5
2 4 6

バージョン

言語

  • C++26

処理系

関連項目

参照