2

我需要一种通用方法来在运行时创建 N 个整数的元组,其中 N 是向量的大小(不超过 20)。例如:

int main() {
    vector<int> vec;
    vec.push_back(31);
    vec.push_back(24);

    auto x = MakeTuple(vec.size());    // x should have the type tuple<int,int>

    return 0;
}

编辑:只是为了澄清......我不能坚持使用向量,因为我需要元组类型来使用 lambda 表达式创建 TBB 流图模板类的对象。

编辑2:显然,我需要解释这个问题。我有非结构化网格,我动态划分为 X 个分区。这些分区中的每一个都与 N 个其他分区相连,其中 N > 1。这些连接定义了我需要用来构建流程图的分区之间的依赖关系。由于网格的结构只有在运行时才知道,所以依赖结构也是如此。因此,我需要一种方法来创建特定的图形节点(TBB 类),这些节点将表示输入依赖关系的元组作为模板参数。

下面是一个如何创建具有两个输入依赖项的 TBB 函数节点的示例:

using namespace tbb:flow;

function_node<tuple<int,int> > *f = 
    new function_node<tuple<int,int>>(g, 1, [=] (tuple<int,int> input) -> void { ... });

join_node<tuple<int,int> *j = new join_node<tuple<int,int>> (g);

make_edge(*j, *f);

现在,假设我们将网格划分为 10 个分区。我们通过检查边列表来确定每个分区的依赖关系。如果有一条边连接两个分区,比如part1part2,那么这些分区之间存在依赖关系。我使用每个分区向量收集依赖信息。现在问题出现了:我需要使用这个依赖信息(存储在向量中)来创建一个函数节点图,这些节点需要基于分区依赖关系的正确元组类型。比如part1part2有如下依赖[2,4,5,9]和[1,3],那么我需要这两个函数节点:

function_node<tuple<int,int> > *f1 = 
    new function_node<tuple<int,int>>(g, 1, [=] (tuple<int,int> input) -> void { ... });

function_node<tuple<int,int,int,int> > *f2 = 
    new function_node<tuple<int,int,int,int>>(g, 1, [=] (tuple<int,int,int,int> input) -> void { ... });
4

2 回答 2

1

元组“维度”是其类型的一部分(通过模板),您不能在运行时从动态选择的值中选择类型。

坚持你的向量。

于 2014-01-02T05:40:17.947 回答
0

由于它必须是一个元组,并且您确实对长度有限制,因此您可以使用工厂方法,例如以下伪代码

generic_type MakeTuple(size_t n) {
    switch(n) {
        case 1:
            return make_tuple(int);
        case 2:
            return make_tuple(int, int);
        ...
        default:
            throw 'oh crap';
}
于 2014-01-02T05:38:36.383 回答