最新发布《数智时代的AI人才粮仓模型解读白皮书(2024版)》,立即领取! 了解详情
写点什么

使用 Brahma 在 GPU 上执行 LINQ

  • 2010-05-18
  • 本文字数:690 字

    阅读完需:约 2 分钟

Brahma 是一个用于并行计算的开源库,它由 C#编写并支持在多种处理器上运行。目前,Brahma 仅包含一个图形处理器(GPU)模块,但是它的模块化结构可以支持更多种类的处理器。使用 Brahma,同一个 C#方法中的语句可以同时运行在 CPU 和 GPU 上,而不需要额外的代码。

Brahma 通过将 LINQ 语句转换成目标处理器代码来执行并行计算,所生成的代码会跟据目标处理器的不同而不同。例如针对 DirectX 会生成 High Level Shading Language ,而针对 OpenGL 则会生成 OpenGL Shading Language 。为了提高性能,LINQ 查询仅被编译一次,然后根据需要多次运行

下面的代码会并行地将一个数组的元素都乘以 2:

复制代码
// 创建计算对象
var computationProvider = new ComputationProvider();
// 创建并行数组,并填充数据
var data = new DataParallelArray<float>(computationProvider, <br></br> new[] { 0f, 1f, 2f, 3f, 4f, 5f, 6f });<p>// 编译 LINQ 查询 </p><br></br>CompiledQuery query = computationProvider.Compile<dataparallelarray><float>><br></br>(<br></br> d => from value in d<br></br> select value * 2f<br></br>);<p>// 在数据上执行查询 </p><br></br>IQueryable result = computationProvider.Run(query, data);<p>// 打印结果 </p><br></br>foreach (float value in result)<br></br> Console.WriteLine(result[i]);<p>// 释放资源 </p><br></br>computationProvider.Dispose();<br></br>data.Dispose();<br></br>result.Dispose();</float></dataparallelarray></float>

Brahma 的源代码二进制文件遵循 Eclipse Public License 1.0

查看英文原文: LINQ on GPU with Brahma

2010-05-18 00:392285
用户头像

发布了 63 篇内容, 共 23.4 次阅读, 收获喜欢 1 次。

关注

评论

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

ansible 模块:pause

ghostwritten

ansible

ansible 模块:lineinfile

ghostwritten

ansible

C语言-strlen与sizeof区别

芒果酱

c++ 编程语言 C语言 5月月更

HarmonyOS 2版本更新!两个小技巧让你告别隐私泄露烦恼

科技汇

制作网站的FAQ时,需要考虑哪些功能,要有哪些注意事项

小炮

FAQ

企评家 | 从机器学习刻画企业成长性画像

企评家

CRM系统可以拯救您的初创企业

低代码小观

初创公司 CRM 中小企业 CRM系统 初创型企业

面试以前上司,能力一般,但他卑微哀求,我该不该放水?

Java全栈架构师

架构 面试 程序人生 java程序员 java 编程

企评家| 嘉凯城集团股份有限公司成长性评价报告摘要

企评家

ansible 模块:modprobe

ghostwritten

ansible

京东优惠价格策略助手

江苏京酷电子商务有限公司

查询优化 京东 优惠券 转链

使用开源软件的优点和缺点是什么

PingCode

netty系列之:给ThreadLocal插上梦想的翅膀,详解FastThreadLocal

程序那些事

Java Netty 程序那些事 5月月更

手慢无!Alibaba五份自研Java程序员进阶宝典限时开源(开发手册+面试指南+性能优化+机器学习+架构手册)

Java全栈架构师

Java 程序员 架构 面试 程序人生

超低延迟传输网络架构在元宇宙场景的应用

网易云信

音视频 元宇宙 传输网络

直播预告|企业智能化转型Meetup V1

星策开源社区

AI BI 智能化转型

ansible 模块:systemd

ghostwritten

ansible systemd

在Rainbond中一键部署高可用 EMQX 集群

北京好雨科技有限公司

Rainbond结合NeuVector实践容器安全管理

北京好雨科技有限公司

iview 如何实现文件上传并限制上传格式和大小

CRMEB

企评家|四川美丰化工股份有限公司成长性报告简述

企评家

揭露ROI提升5倍的秘密!火山引擎A/B测试白皮书重磅发布(内附下载链接)

字节跳动数据平台

字节跳动 数字营销 ab测试

spring中如何自己去实现一个starter

ZuccRoger

5月月更

ansible 模块:template

ghostwritten

ansible

ansible 模块:include_tasks

ghostwritten

ansible

Zadig v1.11.0 发布:不止于环境,与开发者一起交付全球业务

Zadig

DevOps 云原生 CI/CD 软件交付

青岛研博基于EMQ物联网数据基础设施在智慧水务平台产品中的实践

EMQ映云科技

物联网 IoT 实践案例 emq 5月月更

GPU服务器:全球市值最大的半导体公司

Finovy Cloud

人工智能 云计算 GPU服务器

String源码解析-String的使用注意

zarmnosaj

5月月更

如何用同一套账号接入整个研发过程?

阿里云云效

云计算 阿里云 运维 研发管理 研发

DDD实战(10):冲刺1战术之服务设计(下)及技术决策

深清秋

DDD 软件架构 软件设计 生鲜电商系统 5月月更

使用Brahma在GPU上执行LINQ_.NET_Abel Avram_InfoQ精选文章