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
(
)
erfordert
std::
default_initializable
<
V
>
&&
std:: default_initializable < F > = default ; |
(1) | (seit C++20) |
|
constexpr
explicit
transform_view
(
V base, F fun
)
;
|
(2) | (seit C++20) |
Konstruiert eine
transform_view
.
1)
Standardkonstruktor.
Wertinitialisiert
die zugrundeliegende Ansicht
base_
und die Transformationsfunktion
fun_
.
2)
Bewegtkonstruiert die zugrundeliegende Ansicht
base_
aus
base
und die Transformationsfunktion
fun_
aus
fun
.
Parameter
| Basis | - | Ansicht |
| Funktion | - | Transformationsfunktion |
Beispiel
Demonstriert π -Approximation mittels Reihenentwicklung des Arkustangens von 1 : atan(1) = π/4 ≈ 1 - 1/3 + 1/5 - 1/7 + 1/9 - 1/11 + ...
Code ausführen
#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 << " (iterations: " << iterations << ")\n"; } std::cout << "π ≈ " << std::numbers::pi << " (std::numbers::pi)\n"; }
Mögliche Ausgabe:
π ≈ 4.000000000000000 (iterations: 1) π ≈ 2.666666666666667 (iterations: 2) π ≈ 3.466666666666667 (iterations: 3) π ≈ 2.895238095238096 (iterations: 4) π ≈ 3.339682539682540 (iterations: 5) π ≈ 3.041839618929403 (iterations: 10) π ≈ 3.131592903558554 (iterations: 100) π ≈ 3.140592653839794 (iterations: 1000) π ≈ 3.141591653589774 (iterations: 1000000) π ≈ 3.141592653589793 (std::numbers::pi)
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrektes Verhalten |
|---|---|---|---|
|
LWG 3714
( P2711R1 ) |
C++20 | der Multi-Parameter-Konstruktor war nicht explicit | als explicit festgelegt |
| P2325R3 | C++20 |
falls
F
nicht
default_initializable
ist, konstruiert der Standardkonstruktor
ein
transform_view
, das kein
F
enthält
|
das
transform_view
ist ebenfalls
nicht
default_initializable
|