- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
最近我一直在考虑使用 TBB 而不是 boost.threads 来加速开发。通常 parallel_for 在大多数情况下都有效,但我这里的情况有点复杂。
有一个需要计算的结构数组,已根据成员变量排序。这是因为变量值与将在计算期间访问的数据相关,并且根据此对结构进行分组将允许串行设计中的缓存一致性。
#include <tbb/tbb.h>
#include <iostream>
struct thing
{
float value_one;
float value_two;
unsigned int sort_id;
};
class functor
{
thing* m_array;
public:
functor(thing* _array) : m_array(_array) {;}
void operator()(const tbb::blocked_range<unsigned int>& r) const
{
for(int i = r.begin(); i != r.end(); ++i)
{
//Doing a computation with array
m_array[i].value_one = m_array[i].value_two * m_array[i].value_two;
}
}
};
int main(int argc, char const *argv[])
{
unsigned int n = 10;
thing* array = new thing[n];
// Note the ordered id groups
array[0].sort_id = 1;
array[1].sort_id = 1;
array[2].sort_id = 1;
array[3].sort_id = 2;
array[4].sort_id = 3;
array[5].sort_id = 5;
array[6].sort_id = 5;
array[7].sort_id = 9;
array[8].sort_id = 9;
array[9].sort_id = 9;
// Do something parallel with array here...
// parallel_for(tbb::blocked_range<unsigned int>(0, n, 2), functor(array));
delete[] array;
return 0;
}
上面给出了一个简化的例子,但实际上我很可能有一个包含大约 30-60 百万个元素的数组。
我知道 parallel_for 会将数组划分为分组范围。但是我希望每个范围都包含特定 id 的所有结构。我不介意该范围是否包含多个 ID 的结构,只要它们是连续的并且包含这两个 ID 的所有结构即可。
int count = 0;
thing** blocks = new thing*[7];
int* sizes = new int[7];
int current_id = 0;
for(unsigned int i = 0; i < n; ++i)
{
if(array[i].sort_id != current_id)
{
current_id = array[i].sort_id;
blocks[count] = &array[i];
sizes[count] = 1;
++count;
}
else
{
sizes[count - 1] += 1;
}
}
parallel_for(tbb::blocked_range<unsigned int>(0, count, 2), functor(blocks, sizes));
我是否应该以某种方式将数组分成由另一个数组指向的较小块,然后并行化(如直接在上面的代码中),如果是这样,执行此操作的有效方法是什么,或者给出的示例是否最佳?是否有更适合解决此问题的 parallel_for 替代方案(例如 task_group)?
最佳答案
这个问题对我来说还不是很清楚,因为您正在混合目标和可能的方法。
如果需要对数组进行排序,有parallel_sort
如果您需要为排序数组建立索引,其中作为键的 sort_id
映射到给定元素组驻留在主数组中的索引,请使用 concurrent_unordered_map
来存储组(如果有大量的组)并使用 parallel_for
来构建它。
如果组数少于数百,可以使用 std::map
或 std::unordered_map
并使用 parallel_reduce
构建部分映射并将它们合并到最终状态。
最后,当您拥有正确的组数据结构时,您可以根据需要在组中使用 parallel_for
。
附言这个:
grouped ranges called tasks that will be added to the stack for computation
我觉得很奇怪。有一个用户仿函数(或 C++11 lambda),可以并行调用它以处理不同的范围 [begin;end)
。如果您将仿函数称为“任务”,没关系,但不要将其与 tbb::task
混合使用。
关于c++ - 使用/为 TBB 构建分组数据结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31015799/
您好,我正在处理 BIRT 报告。我有一个查询,我必须对父级的重复数据进行分组,但子级也不能分组! 在我的查询中: item 是父项,item_ledger_entry 是子项。我有来自 item.N
我正在使用 GA API。 这是针对 MCF 目标报告(底部)的标准目标完成指标表(顶部) 看一下这个: 总数加起来 (12,238),但看看按 channel 分组的分割有多么不同!我以为这些会很接
我正在开发一个流量计数器,我想获得 IP 和重复计数,但是如何? 就像是 :select ip, count(ip) from Redirect 返回 : null total ip count 重定
我尝试编写一个正则表达式来匹配条件表达式,例如: a!=2 1+2=2+a 我尝试提取运算符。我当前的正则表达式是“.+([!=<>]+).+” 但问题是匹配器总是尝试匹配组中可能的最短字符串
在 MS Transact SQL 中,假设我有一个这样的表(订单): Order Date Order Total Customer # 09/30/2008 8
我想按 m.ID 分组,并对每个 m.id 求和 (pm.amount_construction* prod.anzahl) 实际上我有以下结果: Meterial_id | amount_const
我想根据多列中的值对值进行分组。这是一个例子: 我想得到输出: {{-30,-50,20},{-20,30,60},{-30,NULL or other value, 20}} 我设法到达: SELE
我正在尝试找出运行此查询的最佳方式。我基本上需要返回在我们的系统中只下了一个订单的客户的“登录”字段列表(登录字段基本上是客户 ID/ key )。 我们系统的一些背景...... 客户在同一日期下的
给定以下mysql结果集: id code name importance '1234', 'ID-CS-B', 'Chocolate Sauce'
大家好,我的数据框中有以下列: LC_REF 1 DT 16 2C 2 DT 16 2C 3 DT 16 2C 1 DT 16 3C 6 DT 16 3C 3
我有这样的 mongoDB 集合 { "_id" : "EkKTRrpH4FY9AuRLj", "stage" : 10, }, { "_id" : "EkKTRrpH4FY9
假设我有一组数据对,其中 index 0 是值,index 1 是类型: input = [ ('11013331', 'KAT'), ('9085267',
java中用stream进行去重,排序,分组 一、distinct 1. 八大基本数据类型 List collect = ListUtil.of(1, 2, 3, 1, 2).stream().fil
基本上,我从 TABLE_A 中的这个开始 France - 100 France - 200 France - 300 Mexico - 50 Mexico - 50 Mexico - 56 Pol
我希望这个正则表达式 ([A-Z]+)$ 将选择此示例中的最后一次出现: AB.012.00.022ABC-1 AB.013.00.022AB-1 AB.014.00.022ABAB-1 但我没有匹配
我创建了一个数据透视表,但数据没有组合在一起。 任何人都可以帮助我获得所需的格式吗? 我为获取数据透视表而编写的查询: DECLARE @cols AS NVARCHAR(MAX), -- f
我想按时间段(月,周,日,小时,...)选择计数和分组。例如,我想选择行数并将它们按 24 小时分组。 我的表创建如下。日期是时间戳。 CREATE TABLE MSG ( MSG_ID dec
在 SQL Server 2005 中,我有一个包含如下数据的表: WTN------------Date 555-111-1212 2009-01-01 555-111-1212 2009-
题 假设我有 k 个标量列,如果它们沿着每列彼此在一定距离内,我想对它们进行分组。 假设简单 k 是 2 并且它们是我唯一的列。 pd.DataFrame(list(zip(sorted(choice
问题 在以下数据框中 df : import random import pandas as pd random.seed(999) sz = 50 qty = {'one': 1, 'two': 2
我是一名优秀的程序员,十分优秀!