当我使用 cuda 时,如何从 std::map 中搜索值
How to search the value from a std::map when I use cuda?
我在std::map中存储了一些东西,它将字符串映射到向量。它的键和值看起来像
key value
"a"-----[1,2,3]
"b"-----[8,100]
"cde"----[7,10]
对于每个线程,它需要处理一个查询。查询如下所示
["a", "b"]
或
["cde", "a"]
所以我需要从地图中获取值,然后做一些其他工作,比如组合它们。因此,对于第一个查询,结果将是
[1,2,3,8,100]
问题是,线程如何访问映射并通过键查找值?
起初,我试图将其存储在全局内存中。但是,看起来它只能将数组从主机传递到设备。
然后我尝试使用推力,但我只能用它来存储矢量。
还有其他方法可以使用吗?或者也许我忽略了一些推力方法?谢谢!
**Ps:我不需要修改地图,我只需要从中读取数据。
我相信
你不太可能从GPU上做任何这些事情中受益,除非你有大量的查询,这些查询都可以一次使用,或者至少是批量的。
如果您没有那么多查询,那么仅传输数据(无论其确切格式/结构如何(可能会浪费。
如果您确实有那么多查询,那么好处仍然完全不清楚,并且取决于许多参数。事实上,您一直在尝试将std::map
用于任何事情,这表明(原因见下文(到目前为止,您还没有认真关注性能。如果确实如此,请不要通过使用 GPU 使您的生活变得困难。
那么std::map
有什么问题呢?没什么,但即使在 CPU 上也非常慢,而在 GPU 上更糟糕。
相关文章:
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 使用一个考虑到std::map中键值的滚动或换行的键
- 有没有办法对std::unordered_set、std::unrdered_map、std::set、std::map
- 将重物插入std::map
- 使用通用值初始化 std::map,不重复
- 仅包含可移动 std::map 的类的移动构造函数不起作用
- C++:当所有条目都保证是唯一时,替代 std::map
- 使用模板化的键类型定义 std::map,该键类型基于作为参数接收的函数
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- C++如何创建 std::map
- 从其他容器中移动构造"std::map"
- 将 std::map::emplace 与返回 shared_ptr 的函数一起使用是否正确?
- C++中 std::map 的运行时复杂度是多少?
- 为什么在 std::map 上移动无法将元素从一个映射移动到另一个映射
- 使用重载 [] 运算符返回 std::map() 的可赋值
- std::map, std::unordered_map - 缩小初始值设定项列表中的转换范围
- C++ 使用枚举类对象分配 std::map 值
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- std::map:当元素不可默认构造时创建/替换元素
- Arduino编译器和STL:使用std::vector和std::map