0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一种将CUDA代码迁移到SYCL和C++的开源工具

趣科技 来源:趣科技 作者:趣科技 2022-06-10 11:17 次阅读

英特尔发布了一项开源工具,该工具可通过名为SYCLomatic的项目,将代码迁移至SYCL1,这有助于开发者更轻松地将CUDA代码迁移到SYCL和C++,从而加速面向异构架构的跨架构编程。这个开源项目能让开发社区共同协作,以推动SYCL标准的采用,这是将开发者从单个厂商的封闭生态系统中解放出来的关键一步。

英特尔oneAPI专家James Reinders表示:“使用SYCL将代码迁移至C++,为代码提供了更强的ISO C++一致性,支持多家供应商以缓解供应商锁定问题,并且支持多种架构,为充分运用新的硬件创新提供灵活性。SYCLomatic是一个可实现大部分工作自动化的宝藏工具,让开发者能更多地关注定制化调优,而不是迁移代码。”

在硬件创新为计算带来多样化异构架构的同时,软件开发也已经变得越来越复杂,很难充分释放CPU和加速器的价值。如今的开发者及其团队普遍缺乏时间、金钱和资源,以适应代码的重写和测试,为这些不同的架构提升应用的性能。开发者正在寻求开放替代方案,以提升时间价值。英特尔正在提供一种更简单、更快捷的方式,让开发者进行硬件选择。

SYCL是一种基于C++的Khronos Group标准,它扩展了C++功能以支持多种架构和非共享内存的配置。为启动该项目,英特尔开源了其DPC++兼容性工具背后的技术,以进一步提升迁移能力,生成更多基于SYCL的应用。跨架构重复利用代码简化了开发工作,减少了持续维护代码所需的时间和成本。

利用带有LLVM差异化的Apache 2.0许可证,托管在GitHub上的SYCLomatic项目为开发者提供了一个社区,让他们能做出贡献并提供反馈,以进一步开放跨CPU、GPUFPGA的异构开发。

SYCLomatic协助开发者将CUDA代码迁移到SYCL,通常可以将90-95%的CUDA代码自动迁移到SYCL代码2。开发人员仅需手动编程剩余的工作,然后对特定架构进行定制化调优,达到所需的性能级别,便可完成这一过程。

研究机构及英特尔客户已成功地使用英特尔® DPC++兼容性工具,该工具采用与SYCLomatic相同的技术,能将CUDA代码迁移到多个厂商架构上的SYCL(或Data Parallel C++,oneAPI的SYCL实现)。这些案例包括斯德哥尔摩大学的GROMACS 20223、柏林祖思研究所(ZIB)的easyWave、三星Medison和Bittware(更多案例请访问oneAPI DevSummit)。许多客户也正在测试当前和即将推出的基于英特尔® Xe架构GPU的代码,包括阿贡国家实验室的极光(Aurora)超级计算机、莱布尼茨超级计算中心(LRZ)、GE医疗等。

SYCLomatic 是一个GitHub项目。GitHub门户网站拥有一个“contributing.md”指南,描述了向项目提供技术贡献的步骤,以确保最大程度的便捷。鼓励开发人员使用该工具,提供反馈并做出贡献,以推动该工具的发展。

HACC(硬件/混合加速宇宙学代码)、宇宙物理学和先进计算(anl.gov)的Steve(Esteban)Rangel表示:“CRK-HACC是一个正在开发的N体宇宙学模拟代码。为了给极光(Aurora)超级计算机做好准备,英特尔DPC++兼容性工具能让我们将20多个核心快速迁移到SYCL。由于当前版本的代码迁移工具不支持迁移到仿函数,我们编写了一个简单的clang工具来重构生成的SYCL源代码,以满足我们的需求。通过开源SYCLomatic项目,我们计划整合此前的工作,以获得更强大的解决方案,并助力让仿函数成为可用迁移选项的一部分。”

审核编辑:汤梓红
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 英特尔
    +关注

    关注

    60

    文章

    9860

    浏览量

    171258
  • 代码
    +关注

    关注

    30

    文章

    4721

    浏览量

    68216
  • CUDA
    +关注

    关注

    0

    文章

    121

    浏览量

    13585
  • 开源工具
    +关注

    关注

    0

    文章

    27

    浏览量

    4438
收藏 人收藏

    评论

    相关推荐

    从TMS320C6211迁移到TMS320C6211B

    电子发烧友网站提供《从TMS320C6211迁移到TMS320C6211B.pdf》资料免费下载
    发表于 10-28 10:25 0次下载
    从TMS320<b class='flag-5'>C</b>6211<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>6211B

    从TMS320C6211B/C6711/C6711B/C6711C迁移到TMS320C6711D

    电子发烧友网站提供《从TMS320C6211B/C6711/C6711B/C6711C迁移到TMS320
    发表于 10-23 10:01 0次下载
    从TMS320<b class='flag-5'>C</b>6211B/<b class='flag-5'>C</b>6711/<b class='flag-5'>C</b>6711B/<b class='flag-5'>C6711C</b><b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>6711D

    从TMS320C6712/C6712C迁移到TMS320C6712D

    电子发烧友网站提供《从TMS320C6712/C6712C迁移到TMS320C6712D.pdf》资料免费下载
    发表于 10-18 11:12 0次下载
    从TMS320<b class='flag-5'>C</b>6712/<b class='flag-5'>C6712C</b><b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>6712D

    从USCI模块迁移到eUSCI模块

    电子发烧友网站提供《从USCI模块迁移到eUSCI模块.pdf》资料免费下载
    发表于 10-18 10:39 0次下载
    从USCI模块<b class='flag-5'>迁移到</b>eUSCI模块

    TMS320C645X DSP从EDMA 2.0版迁移到EDMA 3.0版

    电子发烧友网站提供《TMS320C645X DSP从EDMA 2.0版迁移到EDMA 3.0版.pdf》资料免费下载
    发表于 10-16 11:29 0次下载
    TMS320<b class='flag-5'>C</b>645X DSP从EDMA 2.0版<b class='flag-5'>迁移到</b>EDMA 3.0版

    从TMS320C64x迁移到TMS320C64x+

    电子发烧友网站提供《从TMS320C64x迁移到TMS320C64x+.pdf》资料免费下载
    发表于 10-16 10:26 0次下载
    从TMS320<b class='flag-5'>C</b>64x<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>64x+

    从TMS320C6713迁移到TMS320C672x

    电子发烧友网站提供《从TMS320C6713迁移到TMS320C672x.pdf》资料免费下载
    发表于 10-16 10:12 0次下载
    从TMS320<b class='flag-5'>C</b>6713<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>672x

    从TMS320C6455迁移到TMS320C6474

    电子发烧友网站提供《从TMS320C6455迁移到TMS320C6474.pdf》资料免费下载
    发表于 10-14 09:20 0次下载
    从TMS320<b class='flag-5'>C</b>6455<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>6474

    从TMS320C5515/05迁移到TMS320C5535/34/33/32

    电子发烧友网站提供《从TMS320C5515/05迁移到TMS320C5535/34/33/32.pdf》资料免费下载
    发表于 10-12 10:53 0次下载
    从TMS320<b class='flag-5'>C</b>5515/05<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>5535/34/33/32

    从TMS320C5515迁移到TMS320C5517

    电子发烧友网站提供《从TMS320C5515迁移到TMS320C5517.pdf》资料免费下载
    发表于 10-12 10:40 0次下载
    从TMS320<b class='flag-5'>C</b>5515<b class='flag-5'>迁移到</b>TMS320<b class='flag-5'>C</b>5517

    DSP/BIOS 5应用程序迁移到SYS/BIOS 6

    电子发烧友网站提供《DSP/BIOS 5应用程序迁移到SYS/BIOS 6.pdf》资料免费下载
    发表于 09-27 10:54 0次下载
    <b class='flag-5'>将</b>DSP/BIOS 5应用程序<b class='flag-5'>迁移到</b>SYS/BIOS 6

    硬件迁移到CC2652R7和CC2652P7

    电子发烧友网站提供《硬件迁移到CC2652R7和CC2652P7.pdf》资料免费下载
    发表于 09-26 11:07 0次下载
    <b class='flag-5'>将</b>硬件<b class='flag-5'>迁移到</b>CC2652R7和CC2652P7

    怎么IR600系列路由器从DM4.0平台迁移到InConnect平台

    4.0 平台些优点,并且功能更加强大,在这里我介绍怎么IR900系列路由器从DeviceManager 4.0 平台迁移到InConnect平台。在这里我介绍怎么IR600系列
    发表于 07-25 08:13

    C/C++代码动态测试工具VectorCAST插桩功能演示#代码动态测试 #C++

    C++代码
    北汇信息POLELINK
    发布于 :2024年04月18日 11:57:45

    c++多行注释快捷键

    C++中,多行注释(也称为块注释)是一种用于注释大段代码或多个语句的方法。当你希望暂时禁用代码或者解释特定部分
    的头像 发表于 11-22 10:24 7914次阅读