std::ranges::transform_view<V,F>:: transform_view
From cppreference.net
<
cpp
|
ranges
|
transform view
C++
Ranges library
|
||||||||||||||||||||||
| Range primitives | |||||||
|
|||||||
| Range concepts | |||||||||||||||||||
|
|||||||||||||||||||
| Range factories | |||||||||
|
|||||||||
| Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||
| Helper items | |||||||||||||||||
|
|
||||||||||||||||
std::ranges::transform_view
| Member functions | ||||
|
transform_view::transform_view
|
||||
|
(C++26)
|
||||
| Deduction guides | ||||
| Iterator | ||||
| Sentinel | ||||
|
transform_view
(
)
requires
std::
default_initializable
<
V
>
&&
std:: default_initializable < F > = default ; |
(1) | (depuis C++20) |
|
constexpr
explicit
transform_view
(
V base, F fun
)
;
|
(2) | (depuis C++20) |
Construit un
transform_view
.
1)
Constructeur par défaut.
Initialise par valeur
la vue sous-jacente
base_
et la fonction de transformation
fun_
.
2)
Construit par déplacement la vue sous-jacente
base_
à partir de
base
et la fonction de transformation
fun_
à partir de
fun
.
Paramètres
| base | - | vue |
| fun | - | fonction de transformation |
Exemple
Démontre π l'approximation en utilisant le développement en série de l'arc tangente de 1 : atan(1) = π/4 ≈ 1 - 1/3 + 1/5 - 1/7 + 1/9 - 1/11 + ...
Exécuter ce code
#include <algorithm> #include <functional> #include <iomanip> #include <iostream> #include <numeric> #include <ranges> int main() { std::cout << std::setprecision(15) << std::fixed; auto atan1term{std::ranges::views::transform ( [](int n) { return ((n % 2) ? -1 : 1) * 1.0 / (2 * n + 1); } )}; for (const int iterations : {1, 2, 3, 4, 5, 10, 100, 1000, 1'000'000}) { auto seq{std::ranges::views::iota(0, iterations) bitor atan1term}; const double accum{*std::ranges::fold_left_first(seq, std::plus())}; std::cout << "π ≈ " << 4 * accum << " (itérations: " << iterations << ")\n"; } std::cout << "π ≈ " << std::numbers::pi << " (std::numbers::pi)\n"; }
Sortie possible :
π ≈ 4.000000000000000 (itérations: 1) π ≈ 2.666666666666667 (itérations: 2) π ≈ 3.466666666666667 (itérations: 3) π ≈ 2.895238095238096 (itérations: 4) π ≈ 3.339682539682540 (itérations: 5) π ≈ 3.041839618929403 (itérations: 10) π ≈ 3.131592903558554 (itérations: 100) π ≈ 3.140592653839794 (itérations: 1000) π ≈ 3.141591653589774 (itérations: 1000000) π ≈ 3.141592653589793 (std::numbers::pi)
Rapports de défauts
Les rapports de défauts modifiant le comportement suivants ont été appliqués rétroactivement aux normes C++ précédemment publiées.
| DR | Appliqué à | Comportement tel que publié | Comportement corrigé |
|---|---|---|---|
|
LWG 3714
( P2711R1 ) |
C++20 | le constructeur multi-paramètres n'était pas explicite | rendu explicite |
| P2325R3 | C++20 |
si
F
n'est pas
default_initializable
, le constructeur par défaut
construit un
transform_view
qui ne contient pas de
F
|
le
transform_view
n'est également
pas
default_initializable
|