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) | (desde C++20) |
|
constexpr
explicit
transform_view
(
V base, F fun
)
;
|
(2) | (desde C++20) |
Construye un
transform_view
.
1)
Constructor por defecto.
Inicializa por valor
la vista subyacente
base_
y la función de transformación
fun_
.
2)
Construye por movimiento la vista subyacente
base_
desde
base
y la función de transformación
fun_
desde
fun
.
Parámetros
| base | - | vista |
| fun | - | función de transformación |
Ejemplo
Demuestra la aproximación de π usando la expansión en serie del arcotangente de 1 : atan(1) = π/4 ≈ 1 - 1/3 + 1/5 - 1/7 + 1/9 - 1/11 + ...
Ejecutar este código
#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"; }
Salida posible:
π ≈ 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)
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
|
LWG 3714
( P2711R1 ) |
C++20 | el constructor multiparámetro no era explícito | hecho explícito |
| P2325R3 | C++20 |
si
F
no es
default_initializable
, el constructor por defecto
construye un
transform_view
que no contiene un
F
|
el
transform_view
tampoco es
default_initializable
|