C++ 可变参数模板参数迭代
c++ variadic template argument iterating
我在这方面经验不足,但我正在尝试创建一个模板函数来评估 n-变量函数在 "rotated" 参数(见下面的示例)和 returns 所有这些值的向量。
例如 n=3 函数 f(x,y,z) 返回的 triple\vector 应该是
< f(x,0,0), f(0,x,0), f(0,0,x) >
我需要的原始版本可能如下所示(不需要 correct\working)
typedef FunctionSignature Function;
template<class Function, size_t Dimensions>
std::array<Function::Out,Dimensions> F(Function::InComponent x)
{
std::array<Function::Out,Dimensions> Result;
for (i=0; i<Dimensions; i++)
Result[i] = Function::f("rotate((x,0,...,0),i)");
return Result;
}
但是如何制作 rotate
东西。
我也希望 运行-time for
可以以某种方式被删除,因为 n
在编译时是众所周知的。
template<class Function, size_t... Is, size_t... Js>
typename Function::Out call_f(typename Function::InComponent x,
std::index_sequence<Is...>,
std::index_sequence<Js...>) {
return Function::f((void(Is), 0)..., x, (void(Js), 0)...);
}
template<class Function, size_t Dimensions, size_t... Is>
std::array<typename Function::Out, Dimensions> F(typename Function::InComponent x,
std::index_sequence<Is...>)
{
return {{ call_f<Function>(x, std::make_index_sequence<Is>(),
std::make_index_sequence<Dimensions - Is - 1>())... }};
}
template<class Function, size_t Dimensions>
std::array<typename Function::Out,Dimensions> F(typename Function::InComponent x)
{
return F<Function, Dimensions>(x, std::make_index_sequence<Dimensions>());
}
对于 C++11,在 SO 上搜索 make_index_sequence
的实现。
Demo.
我在这方面经验不足,但我正在尝试创建一个模板函数来评估 n-变量函数在 "rotated" 参数(见下面的示例)和 returns 所有这些值的向量。
例如 n=3 函数 f(x,y,z) 返回的 triple\vector 应该是
< f(x,0,0), f(0,x,0), f(0,0,x) >
我需要的原始版本可能如下所示(不需要 correct\working)
typedef FunctionSignature Function;
template<class Function, size_t Dimensions>
std::array<Function::Out,Dimensions> F(Function::InComponent x)
{
std::array<Function::Out,Dimensions> Result;
for (i=0; i<Dimensions; i++)
Result[i] = Function::f("rotate((x,0,...,0),i)");
return Result;
}
但是如何制作 rotate
东西。
我也希望 运行-time for
可以以某种方式被删除,因为 n
在编译时是众所周知的。
template<class Function, size_t... Is, size_t... Js>
typename Function::Out call_f(typename Function::InComponent x,
std::index_sequence<Is...>,
std::index_sequence<Js...>) {
return Function::f((void(Is), 0)..., x, (void(Js), 0)...);
}
template<class Function, size_t Dimensions, size_t... Is>
std::array<typename Function::Out, Dimensions> F(typename Function::InComponent x,
std::index_sequence<Is...>)
{
return {{ call_f<Function>(x, std::make_index_sequence<Is>(),
std::make_index_sequence<Dimensions - Is - 1>())... }};
}
template<class Function, size_t Dimensions>
std::array<typename Function::Out,Dimensions> F(typename Function::InComponent x)
{
return F<Function, Dimensions>(x, std::make_index_sequence<Dimensions>());
}
对于 C++11,在 SO 上搜索 make_index_sequence
的实现。
Demo.