写点什么

Boost 1.61 发布,带来了新的 CPU/CPU 计算、插件管理和其他程序库

  • 2016-06-14
  • 本文字数:1444 字

    阅读完需:约 5 分钟

在 1.60 版本发布的 5 个月后,Boost 发布了 1.61 版本,增加了一些新程序库,同时更新了许多程序库。

Boost 1.61 包括 4 个新程序库:

  • Compute ,使用 OpenCL 为多核 CPU 和 GPU 运算平台提供 C++ 接口。OpenCL 是一个开放标准,它允许创建运行在异构运算设备(如 CPU 和 GPU)上的应用程序。该程序库提供管理 OpenCL 对象的类,例如设备(device)、内核(kernel)和命令队列(command_queues),同时也提供了允许开发者处理计算设备、与计算设备传输数据、迭代和转换计算设备的函数。这使得我们可以将数据传输到默认计算设备上,对数据进行转换,最后复制回宿主机:
复制代码
std::vector<float> host_vector(10000);
// 定义宿主机内容向量
// 获取默认设备,并且设置上下文
compute::device device = compute::system::default_device();
compute::context context(device);
compute::command_queue queue(context, device);
// 在设备上创建向量
compute::vector<float> device_vector(host_vector.size(), context);
// 将数据从宿主机传输到设备上
compute::copy(
host_vector.begin(), host_vector.end(), device_vector.begin(), queue
);
// 就地计算每个元素的平方根
compute::transform(
device_vector.begin(),
device_vector.end(),
device_vector.begin(),
compute::sqrt<float>(),
queue
);
// 将数据复制回宿主机
compute::copy(
device_vector.begin(), device_vector.end(), host_vector.begin(), queue
);</float></float></float>
  • DLL ,一个旨在开发跨平台、可移植插件的程序库。DLL 允许开发者加载其他程序库、导入本地函数和变量、查询程序库的段和符号表等。DLL 插件可以通过 extern “C”和 BOOST_SYMBOL_EXPORT 定义。客户端应用程序可以通过执行 DLL 插件的 import 函数加载动态链接库:
复制代码
// 持有指向插件变量指针的变量
boost::shared_ptr<my_plugin_api> plugin;
plugin = dll::import<my_plugin_api>(
full_path_to_library,
name_of_symbol_to_import,
dll::load_mode::append_decorations
);</my_plugin_api></my_plugin_api>

DLL 也支持动态链接库的引用计数,以更好的控制已加载插件的生命周期、在插件卸载时执行回调函数和其他一些功能。

  • Hana ,一个元编程库,它能够提供操作异构序列的高级算法。对比现有元编程库,例如 Boost.MPL Boost.Fusion ,Hana 统一了类型和值的操作。Hana 提供了一系列容器类型,例如元组(tuple)、含无效值容器(optional)、映射(map)等,还有操作这些容器的算法集合,例如折叠(fold)、压缩(zip)、扁平化(flatten)等。
  • Metaparse ,一个用于生成解析器的程序库,它能够在编译时解析文本或代码,并且可以返回一个类型、一个常量和一个运行时调用的 C++ 函数等。Metaparse 特别倾向用于创建一种嵌入式领域特定语言。Metaparse 允许使用类似EBNF 范式的语法定义上下文无关语法。它和另一个著名的元编程库 Boost.Spirit 的主要区别是后者产生运行时解析器,而 Metaparse 产生编译时解析器。

前文提到过,Boost 1.61 也更新了许多现有程序库,包括 Multiprecision (多倍精度数值库)、 Optional (含无效值容器库)、 Geometry (几何库)、 Fusion (容器库)等等。

查看英文原文: Boost 1.61 Brings New Libraries for CPU/CPU Computation, Plugin Management, and More


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-06-14 19:002823

评论

发布
暂无评论
发现更多内容

YashanDB的行业应用广泛性与灵活性分析

数据库砖家

构建易受攻击的AWS DevOps环境:CloudGoat攻防实战

qife122

云安全攻防 AWS安全

Akka.NET高性能分布式Actor框架完全指南

qife122

微服务 分布式系统 Akka

YashanDB如何配合AI技术实现智能决策

数据库砖家

YashanDB的用户友好界面:实现高效操作的秘密

数据库砖家

YashanDB如何帮助企业快速响应市场变化?

数据库砖家

YashanDB系统集成的最佳实践

数据库砖家

DXC 和微软研究院发现,安全领导者在采用人工智能安全工具方面滞后

财见

Elasticsearch 备份:snapshot 镜像使用篇

极限实验室

elasticsearch Snapshot backup

springboot项目操作mysql出现锁表问题情况

刘大猫

人工智能 智能医疗 远程医疗 临床试验 医学统计

YashanDB的灾备恢复机制解析

数据库砖家

YashanDB如何实现跨平台数据集成?

数据库砖家

YashanDB在金融行业中的应用实例

数据库砖家

YashanD在智能制造中的应用潜力

数据库砖家

docx-handlebars 一个用于处理 DOCX 文件 Handlebars 模板的 Rust 库,支持多平台使用

黄智勇

webassembly 模板引擎 文档处理 Rust开发 跨平台库

YashanDB如何助力企业数字化转型?

数据库砖家

YashanDB在医疗行业的应用与机遇

数据库砖家

AI小说生成器:智能创作与一致性维护的全流程解决方案

qife122

自然语言处理 AI写作

YashanDB的性能优化方法:你的实用指南

数据库砖家

YashanDB如何支持多种数据类型与格式?

数据库砖家

xlsx-handlebars 用于处理 XLSX 文件 Handlebars 模板的 Rust 库,支持多平台使用

黄智勇

CodexField RWA:让内容实现确权、计量、回报的资产化蜕变

BlockChain先知

React 19.2 重磅更新!这几个新特性终于来了

Immerse

React Native

YashanDB的未来趋势:技术与市场的结合

数据库砖家

YashanDB在电商行业的应用优势

数据库砖家

YashanDB与云服务平台的最佳整合策略

数据库砖家

50美元“Battering RAM”攻击可破解机密计算防御

qife122

机密计算 内存加密

重构内容价值:CodexField RWA打造内容确权、计量、回报的真实资产

股市老人

CodexField RWA的破局点:内容转确权、计量、回报的真实资产

加密眼界

在AI技术唾手可得的时代,挖掘新需求成为核心竞争力——某知名离线转录工具需求洞察

qife122

AI应用 语音转录

重构内容价值:CodexField RWA打造内容确权、计量、回报的真实资产

石头财经

Boost 1.61发布,带来了新的CPU/CPU计算、插件管理和其他程序库_C++_Sergio De Simone_InfoQ精选文章