首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >c++:将向量转换为元组

c++:将向量转换为元组
EN

Stack Overflow用户
提问于 2015-02-09 21:14:50
回答 3查看 10.6K关注 0票数 11

如何将std::vector转换为std::tuple?我有过

代码语言:javascript
复制
class T { };
int cnt = 3;
vector<T*> tv;
for (int i = 0; i < cnt; ++i) {
  tv.push_back(new T());
}

我想要得到

代码语言:javascript
复制
auto tp = std::tie(*tv[0], *tv[1], *tv[2]);

我怎么才能得到这个tp呢?如果cnt足够大,我不能手动编写这个tp。

代码语言:javascript
复制
  std::vector<
  ConvConnection<
  decltype(inputLayer),
  decltype(*C1[0]),
  decltype(*Conn1Opt[0]),
  RandomInitialization<arma::mat>,
  arma::mat
  >* > Conn1(6);

  for (size_t i = 0; i < 6; ++i) {
    Conn1.push_back(new  ConvConnection<
                    decltype(inputLayer),
                    decltype(*C1[0]),
                    decltype(*Conn1Opt[0]),
                    RandomInitialization<arma::mat>,
                    arma::mat
                    >(inputLayer, *C1[i], *Conn1Opt[i], 5, 5));
  }

这就是代码。这里只有6,但我还需要一些大小超过100的向量。我需要将这个向量转换为一个元组。

EN

回答 3

Stack Overflow用户

发布于 2015-02-09 21:28:34

但是,如果您要做的只是为某个N创建一个常量表达式的元组<f(0), f(1), ..., f(N-1)>,那么使用索引序列技巧就可以做到:

代码语言:javascript
复制
template <typename F, size_t... Is>
auto gen_tuple_impl(F func, std::index_sequence<Is...> ) {
    return std::make_tuple(func(Is)...);
}

template <size_t N, typename F>
auto gen_tuple(F func) {
    return gen_tuple_impl(func, std::make_index_sequence<N>{} );
}

我们可以像这样使用它:

代码语言:javascript
复制
// make a tuple of the first 10 squares: 0, 1, 4, ..., 81
auto squares = gen_tuple<10>([](size_t i){ return i*i;});

对于您的特定用例,这将是:

代码语言:javascript
复制
auto connections = gen_tuple<6>([&](size_t i) {
    return new ConvConnection<
                decltype(inputLayer),
                decltype(*C1[0]),
                decltype(*Conn1Opt[0]),
                RandomInitialization<arma::mat>,
                arma::mat
                >(inputLayer, *C1[i], *Conn1Opt[i], 5, 5);
});
票数 17
EN

Stack Overflow用户

发布于 2015-02-09 21:37:14

代码语言:javascript
复制
template <typename T, std::size_t... Indices>
auto vectorToTupleHelper(const std::vector<T>& v, std::index_sequence<Indices...>) {
  return std::make_tuple(v[Indices]...);
}

template <std::size_t N, typename T>
auto vectorToTuple(const std::vector<T>& v) {
  assert(v.size() >= N);
  return vectorToTupleHelper(v, std::make_index_sequence<N>());
}

多亏了自动扣除,这是可以的。在C++11中,如果没有自动推导,您必须编写带有尾随decltype的返回类型。您还必须实现自己的index_sequence

票数 14
EN

Stack Overflow用户

发布于 2015-02-09 21:18:53

因为向量的大小在运行时是已知的,但是tuple类型(包括它的大小)必须在编译时是已知的。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28410697

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档