基于多核异构计算的人工智能开发方法及装置.pdf
《基于多核异构计算的人工智能开发方法及装置.pdf》由会员分享,可在线阅读,更多相关《基于多核异构计算的人工智能开发方法及装置.pdf(15页完成版)》请在专利查询网上搜索。
1、(19)中华人民共和国国家知识产权局 (12)发明专利申请 (10)申请公布号 (43)申请公布日 (21)申请号 202010215082.7 (22)申请日 2020.03.24 (71)申请人 杭州博雅鸿图视频技术有限公司 地址 310013 浙江省杭州市西湖区转塘科 技经济区块16号3幢249室 (72)发明人 闫野鹤程有良梁天乐吴飞红 陈科 (74)专利代理机构 北京辰权知识产权代理有限 公司 11619 代理人 付婧 (51)Int.Cl. G06F 9/38(2006.01) G06F 9/50(2006.01) (54)发明名称 一种基于多核异构计算的人工智能开发方 法及装置 。
2、(57)摘要 本申请提出一种基于多核异构计算的人工 智能开发方法及装置, 该方法包括: 创建异构芯 片的架构模式对应的有向图; 根据用户提交的多 个人工智能算法及算法数据流向信息, 创建有向 无环图; 根据有向无环图, 生成对应的算法调度 表; 根据算法调度表, 通过有向图对有向无环图 中的多个人工智能算法进行运算处理。 本申请将 异构芯片中集成的多个人工智能引擎抽象为有 向图, 将用户开发的多个人工智能算法及各人工 智能算法之间的数据流向抽象为有向无环图。 通 过异构芯片对应的有向图每个节点上加载的人 工智能引擎并行执行有向无环图的节点上加载 的人工智能算法, 提高了人工智能引擎的利用率 和。
3、人工智能芯片的算力, 简化了人工智能程序开 发的难度。 权利要求书2页 说明书9页 附图3页 CN 111399911 A 2020.07.10 CN 111399911 A 1.一种基于多核异构计算的人工智能开发方法, 其特征在于, 所述方法包括: 创建异构芯片的架构模式对应的有向图; 根据用户提交的多个人工智能算法及算法数据流向信息, 创建所述人工智能算法对应 的有向无环图; 根据所述有向无环图, 生成对应的算法调度表; 根据所述算法调度表, 通过所述有向图对所述有向无环图中的所述多个人工智能算法 进行运算处理。 2.根据权利要求1所述的方法, 其特征在于, 所述创建异构芯片的架构模式对应。
4、的有向 图, 包括: 确定异构芯片的架构模式中包含的人工智能引擎的数目; 创建所述数目个节点, 且将任意两个节点之间相互连接; 将所述异构芯片中的各个人工智能引擎分别加载到创建的不同节点上, 得到所述异构 芯片的架构模式对应的有向图。 3.根据权利要求1所述的方法, 其特征在于, 所述根据用户提交的多个人工智能算法及 算法数据流向信息, 创建所述人工智能算法对应的有向无环图, 包括: 根据用户提交的人工智能算法的数目, 创建该数目个节点; 将所述用户提交的各个人工智能算法分别加载到创建的不同节点上; 根据所述用户提交的用于指示所述各个人工智能算法之间数据流向的算法数据流向 信息, 确定创建的所。
5、述节点之间的连接关系, 得到所述人工智能算法对应的有向无环图。 4.根据权利要求1所述的方法, 其特征在于, 所述根据所述有向无环图, 生成对应的算 法调度表, 包括: 对所述有向无环图中的节点进行拓扑排序, 确定所述有向无环图中各节点的执行顺序 及每个节点的数据流向信息; 根据所述各节点的执行顺序及每个节点的数据流向信息, 生成所述有向无环图对应的 算法调度表。 5.根据权利要求1-4任一项所述的方法, 其特征在于, 所述根据所述有向无环图, 生成 对应的算法调度表之前, 还包括: 通过预设校验算法校验所述有向无环图中是否包含数据环路; 若所述有向无环图中不包含数据环路, 则执行所述根据所述。
6、有向无环图, 生成对应的 算法调度表的操作; 若所述有向无环图中包含数据环路, 则显示用于指示所述多个人工智能算法中存在逻 辑错误的报错信息。 6.根据权利要求1所述的方法, 其特征在于, 所述根据所述算法调度表, 通过所述有向 图对所述有向无环图中的所述多个人工智能算法进行运算处理, 包括: 调用预设搜索算法从所述算法调度表中确定出当前的待执行节点及其对应的数据流 向信息; 将所述有向无环图中所述待执行节点上加载的人工智能算法映射到所述有向图的节 点上; 通过所述有向图的节点上加载的人工智能引擎执行映射的所述人工智能算法, 并将执 权利要求书 1/2 页 2 CN 111399911 A 2。
7、 行结果传输给所述数据流向信息对应的下一节点。 7.一种基于多核异构计算的人工智能开发装置, 其特征在于, 所述装置包括: 有向图创建模块, 用于创建异构芯片的架构模式对应的有向图; 有向无环图创建模块, 用于根据用户提交的多个人工智能算法及算法数据流向信息, 创建所述人工智能算法对应的有向无环图; 调度表生成模块, 用于根据所述有向无环图, 生成对应的算法调度表; 异构运算模块, 用于根据所述算法调度表, 通过所述有向图对所述有向无环图中的所 述多个人工智能算法进行运算处理。 8.根据权利要求7所述的装置, 其特征在于, 所述异构运算模块, 用于调用预设搜索算 法从所述算法调度表中确定出当前。
8、的待执行节点及其对应的数据流向信息; 将所述有向无 环图中所述待执行节点上加载的人工智能算法映射到所述有向图的节点上; 通过所述有向 图的节点上加载的人工智能引擎执行映射的所述人工智能算法, 并将执行结果传输给所述 数据流向信息对应的下一节点。 9.一种电子设备, 包括存储器、 处理器及存储在所述存储器上并可在所述处理器上运 行的计算机程序, 其特征在于, 所述处理器运行所述计算机程序以实现如权利要求1-6任一 项所述的方法。 10.一种计算机可读存储介质, 其上存储有计算机程序, 其特征在于, 所述程序被处理 器执行实现如权利要求1-6中任一项所述的方法。 权利要求书 2/2 页 3 CN 。
9、111399911 A 3 一种基于多核异构计算的人工智能开发方法及装置 技术领域 0001 本申请属于人工智能技术领域, 具体涉及一种基于多核异构计算的人工智能开发 方法及装置。 背景技术 0002 在终端侧高效运行人工智能程序需要多核异构计算。 因为不同人工智能应用场景 的功耗和对运算资源的需求各不相同, 仅靠单颗人工智能内核无法以最佳方式运行不同应 用场景下的人工智能程序, 所以需要可编程的异构计算。 但是随着异构CPU(Central Processing Unit, 中央处理器)集成的AIEngine(人工智能引擎)越多, 开发程序的难度越 高, 并且AIEngine利用率极低, 导。
10、致异构CPU的算力达不到预期。 发明内容 0003 本申请提出一种基于多核异构计算的人工智能开发方法及装置, 将异构芯片中集 成的多个人工智能引擎抽象为有向图, 将用户开发的多个人工智能算法及各人工智能算法 之间的数据流向抽象为有向无环图。 通过异构芯片对应的有向图每个节点上加载的人工智 能引擎并行执行有向无环图的节点上加载的人工智能算法, 提高了人工智能引擎的利用率 和人工智能芯片的算力, 简化了人工智能程序开发的难度。 0004 本申请第一方面实施例提出了一种基于多核异构计算的人工智能开发方法, 所述 方法包括: 0005 创建异构芯片的架构模式对应的有向图; 0006 根据用户提交的多个。
11、人工智能算法及算法数据流向信息, 创建所述人工智能算法 对应的有向无环图; 0007 根据所述有向无环图, 生成对应的算法调度表; 0008 根据所述算法调度表, 通过所述有向图对所述有向无环图中的所述多个人工智能 算法进行运算处理。 0009 在本申请的一些实施例中, 所述创建异构芯片的架构模式对应的有向图, 包括: 0010 确定异构芯片的架构模式中包含的人工智能引擎的数目; 0011 创建所述数目个节点, 且将任意两个节点之间相互连接; 0012 将所述异构芯片中的各个人工智能引擎分别加载到创建的不同节点上, 得到所述 异构芯片的架构模式对应的有向图。 0013 在本申请的一些实施例中,。
12、 所述根据用户提交的多个人工智能算法及算法数据流 向信息, 创建所述人工智能算法对应的有向无环图, 包括: 0014 根据用户提交的人工智能算法的数目, 创建该数目个节点; 0015 将所述用户提交的各个人工智能算法分别加载到创建的不同节点上; 0016 根据所述用户提交的用于指示所述各个人工智能算法之间数据流向的算法数据 流向信息, 确定创建的所述节点之间的连接关系, 得到所述人工智能算法对应的有向无环 说明书 1/9 页 4 CN 111399911 A 4 图。 0017 在本申请的一些实施例中, 所述根据所述有向无环图, 生成对应的算法调度表, 包 括: 0018 对所述有向无环图中的。
13、节点进行拓扑排序, 确定所述有向无环图中各节点的执行 顺序及每个节点的数据流向信息; 0019 根据所述各节点的执行顺序及每个节点的数据流向信息, 生成所述有向无环图对 应的算法调度表。 0020 在本申请的一些实施例中, 所述根据所述有向无环图, 生成对应的算法调度表之 前, 还包括: 0021 通过预设校验算法校验所述有向无环图中是否包含数据环路; 0022 若所述有向无环图中不包含数据环路, 则执行所述根据所述有向无环图, 生成对 应的算法调度表的操作; 0023 若所述有向无环图中包含数据环路, 则显示用于指示所述多个人工智能算法中存 在逻辑错误的报错信息。 0024 在本申请的一些实。
14、施例中, 所述根据所述算法调度表, 通过所述有向图对所述有 向无环图中的所述多个人工智能算法进行运算处理, 包括: 0025 调用预设搜索算法从所述算法调度表中确定出当前的待执行节点及其对应的数 据流向信息; 0026 将所述有向无环图中所述待执行节点上加载的人工智能算法映射到所述有向图 的节点上; 0027 通过所述有向图的节点上加载的人工智能引擎执行映射的所述人工智能算法, 并 将执行结果传输给所述数据流向信息对应的下一节点。 0028 本申请第二方面的实施例中提供了一种基于多核异构计算的人工智能开发装置, 所述装置包括: 0029 有向图创建模块, 用于创建异构芯片的架构模式对应的有向图。
15、; 0030 有向无环图创建模块, 用于根据用户提交的多个人工智能算法及算法数据流向信 息, 创建所述人工智能算法对应的有向无环图; 0031 调度表生成模块, 用于根据所述有向无环图, 生成对应的算法调度表; 0032 异构运算模块, 用于根据所述算法调度表, 通过所述有向图对所述有向无环图中 的所述多个人工智能算法进行运算处理。 0033 在本申请的一些实施例中, 所述异构运算模块, 用于调用预设搜索算法从所述算 法调度表中确定出当前的待执行节点及其对应的数据流向信息; 将所述有向无环图中所述 待执行节点上加载的人工智能算法映射到所述有向图的节点上; 通过所述有向图的节点上 加载的人工智能。
16、引擎执行映射的所述人工智能算法, 并将执行结果传输给所述数据流向信 息对应的下一节点。 0034 本申请第三方面的实施例中提供了一种电子设备, 包括存储器、 处理器及存储在 所述存储器上并可在所述处理器上运行的计算机程序, 所述处理器运行所述计算机程序以 实现上述第一方面所述的方法。 0035 本申请第四方面的实施例中提供了一种计算机可读存储介质, 其上存储有计算机 说明书 2/9 页 5 CN 111399911 A 5 程序, 所述程序被处理器执行实现上述第一方面所述的方法。 0036 本申请实施例中提供的技术方案, 至少具有如下技术效果或优点: 0037 本申请实施例将异构芯片中集成的多。
17、个人工智能引擎抽象为有向图, 将用户开发 的多个人工智能算法及各个人工智能算法之间的数据流向抽象为有向无环图。 通过异构芯 片对应的有向图每个节点上加载的人工智能引擎并行执行有向无环图的节点上加载的人 工智能算法, 提高了人工智能引擎的利用率, 增加了人工智能芯片的算力, 简化了人工智能 程序开发的难度。 0038 本申请附加的方面和优点将在下面的描述中部分给出, 部分将从下面的描述中变 的明显, 或通过本申请的实践了解到。 附图说明 0039 通过阅读下文优选实施方式的详细描述, 各种其他的优点和益处对于本领域普通 技术人员将变得清楚明了。 附图仅用于示出优选实施方式的目的, 而并不认为是对。
18、本申请 的限制。 而且在整个附图中, 用相同的参考符号表示相同的部件。 0040 在附图中: 0041 图1示出了本申请一实施例所提供的一种基于多核异构计算的人工智能开发方法 的流程示意图; 0042 图2示出了本申请一实施例所提供的有向图的示意图; 0043 图3示出了本申请一实施例所提供的有向无环图的示意图; 0044 图4示出了本申请一实施例所提供的一种基于多核异构计算的人工智能开发装置 的结构示意图; 0045 图5示出了本申请一实施例所提供的一种电子设备的结构示意图; 0046 图6示出了本申请一实施例所提供的一种存储介质的示意图。 具体实施方式 0047 下面将参照附图更详细地描述。
19、本申请的示例性实施方式。 虽然附图中显示了本申 请的示例性实施方式, 然而应当理解, 可以以各种形式实现本申请而不应被这里阐述的实 施方式所限制。 相反, 提供这些实施方式是为了能够更透彻地理解本申请, 并且能够将本申 请的范围完整的传达给本领域的技术人员。 0048 需要注意的是, 除非另有说明, 本申请使用的技术术语或者科学术语应当为本申 请所属领域技术人员所理解的通常意义。 0049 下面结合附图来描述根据本申请实施例提出的一种基于多核异构计算的人工智 能开发方法及装置。 0050 本申请实施例提供了一种基于多核异构计算的人工智能开发方法。 该方法为了提 高人工智能引擎的利用率, 增加人。
20、工智能芯片的算力, 同时简化人工智能应用的开发难度, 采用经典的有向无环图和有向有环图作为实现Pipeline(线性通信模型)功能的核心数据 结构, 同时采用AOV(Activity On Vertex NetWork, 活动点网)作为人工智能应用的任务的 逻辑表示, 使用BFS(Breadth First Search, 广度优先搜索)算法检索AOV网络, 实现有向无 环图的节点的快速调度以及向人工智能引擎线程的有向图的映射。 说明书 3/9 页 6 CN 111399911 A 6 0051 参见图1, 该方法具体包括以下步骤: 0052 步骤101: 创建异构芯片的架构模式对应的有向图。。
21、 0053 有向图是一种数据结构, 有向图由节点的有穷非空集合和节点之间边的集合组 成, 通常表示为G(V,E)。 其中, G表示一个图, V是图G中节点的集合, E是图G中边的集合, E具 有方向性。 有向图侧重描述的是节点之间的方向, 节点与节点之间的数据流向可以是双向 的也可以是单向的。 如图2所示的有向图中, 用圆圈表示节点, 用箭头表示边。 因为每个节点 和节点之间对应着一定的方向关系, 所以图2中用一个箭头来表示从一个节点到另外一个 节点的有向关系。 节点与节点之间可以形成一个环, 节点与节点之间可以双向互通且节点 与节点之间的连接是任意的, 没有规律的。 0054 本申请实施例的。
22、执行主体为终端, 终端上配置有异构芯片, 异构芯片可以为ASMP (Asymmetric Multi-Processing, 不对称多处理)芯片。 异构芯片的架构模式中包括处理器 和集成的多个人工智能引擎, 如异构芯片采用的是CPU加5个人工智能引擎的架构模式等。 本申请实施例根据异构芯片的架构模式, 将异构芯片包括的人工智能引擎在本地CPU上抽 象为有向图。 0055 具体地, 确定异构芯片的架构模式中包含的人工智能引擎的数目, 创建该数目个 节点, 且将任意两个节点之间相互连接。 将异构芯片中的各个人工智能引擎分别加载到创 建的不同节点上, 得到异构芯片的架构模式对应的有向图。 0056 。
23、例如, 假设异构芯片采用的是CPU加5个人工智能引擎的架构模式, 则通过 Pipeline初始化时先创建5个节点, 每个节点之间相互连接, 互连互通。 将异构芯片中的每 个人工智能引擎分别加载到不同的节点上, 得到该异构芯片的架构模式对应的有向图。 0057 上述异构芯片对应的有向图在Pipeline初始化阶段创建, 其生命周期与用户开发 的人工智能应用的生命周期相同。 有向图的创建与异构芯片的架构模式相关, 但不与特定 的芯片绑定, 本申请实施例提供的方法可以以框架的形式实现快速移植与适配。 有向图初 始化完毕之后操作系统会将该有向图挂起阻塞, 直到Pipeline将其唤醒。 0058 通过。
24、上述方式将异构芯片包括的人工智能引擎抽象成有向图, 后续可以通过有向 图中各个节点上加载的人工智能引擎并行处理用户开发的人工智能算法, 提高人工智能芯 片的算力, 提高处理效率。 0059 步骤102: 根据用户提交的多个人工智能算法及算法数据流向信息, 创建人工智能 算法对应的有向无环图。 0060 有向无环图也是一种数据结构, 有向无环图是由节点的有穷非空集合和节点之间 边的集合组成, 通常表示为G(V,E)。 其中, G表示一个图, V是图G中节点的集合, E是图G中边 的集合, E具有方向性。 有向无环图无法从某个节点出发经过若干条边回到该节点。 如图3所 示的有向无环图中包括具有依赖。
25、关系7个及节点和8条边。 在异构多核芯片调度中使用有向 无环图, 相比于其他数据结构与算法有很大的优势, 可以简化人工智能程序的开发难度, 使 得人工智能程序开发更加快速和轻量化。 0061 用户在进行人工智能开发过程中, 会开发出多个人工智能算法, 每个人工智能算 法都有自己对应的算法数据流向信息, 人工智能算法对应的算法数据流向信息用于指示该 人工智能算法的数据流向, 即指示该人工智能算法的运算结果需要传输给哪个其他的人工 智能算法。 用户在开发过程中将其开发的多个人工智能算法及每个人工智能算法对应的数 说明书 4/9 页 7 CN 111399911 A 7 据流向信息提交给终端。 00。
26、62 终端根据用户提交的人工智能算法的数目, 创建该数目个节点; 将用户提交的各 个人工智能算法分别加载到创建的不同节点上。 用户提交的人工智能算法与创建的节点一 一对应, 将人工智能算法加载到其对应的节点上。 然后根据用户提交的用于指示各个人工 智能算法之间数据流向的算法数据流向信息, 确定创建的节点之间的连接关系, 得到人工 智能算法对应的有向无环图。 0063 在本申请实施例中, 终端上的Pipeline提供了有向无环图调度机制, 有向无环图 主要承载程序的算法逻辑, 主要包括算法数据流向以及人工智能算法的逻辑组成。 有向无 环图的节点表示具体的算法, 边表示每个算法之间的逻辑关系。 P。
27、ipeline支持程序对节点 与边的增加、 删除、 更新等操作。 0064 步骤103: 根据有向无环图, 生成对应的算法调度表。 0065 通过步骤102的操作生成有向无环图之后, 通过预设校验算法校验有向无环图中 是否包含数据环路; 若有向无环图中不包含数据环路, 则执行步骤103的操作。 若有向无环 图中包含数据环路, 则显示用于指示多个人工智能算法中存在逻辑错误的报错信息。 0066 上 述 预 设 校 验 算 法 可 以 为 P i p e l i n e 提 供 的 校 验 算 法 , 如 函 数 gvspPipelineListVerify(), 该函数首先会对上述创建的有向无环。
28、图按照节点属性进行 拓扑排序, 排列出有向无环图中各个节点执行的先后顺序, 然后校验所有的节点中是否不 包含数据环路, 如果校验出包含数据环路, 则函数gvspPipelineListVerify()会校验失 败, 报错并退出。 0067 通过对有向无环图进行校验, 确保有向无环图的节点之间不能形成数据环路, 如 有向无环图之中有数据环路存在, 则调度有向无环图时会出现死锁的问题。 因此通过校验 能够提高后续调度运算的效率, 减少运算资源的浪费。 0068 通过上述方式校验出步骤102创建的有向无环图中不包含数据环路之后, 对有向 无环图中的节点进行拓扑排序, 确定有向无环图中各节点的执行顺序。
29、及每个节点的数据流 向信息; 根据各节点的执行顺序及每个节点的数据流向信息, 生成有向无环图对应的算法 调度表, 该算法调度表中记录了有向无环图中节点执行的先后顺序以及节点的逻辑指向, 该算法调度表可以为PSI(PipelineScheduleImplementation)。 0069 步骤104: 根据算法调度表, 通过有向图对有向无环图中的多个人工智能算法进行 运算处理。 0070 通过步骤103的操作生成算法调度表之后, 调用预设搜索算法从算法调度表中确 定出当前的待执行节点及其对应的数据流向信息; 将有向无环图中待执行节点上加载的人 工智能算法映射到有向图的节点上; 通过有向图的节点上。
30、加载的人工智能引擎执行映射的 人工智能算法, 并将执行结果传输给数据流向信息对应的下一节点。 0071 上述预设搜索算法可以为BFS算法。 终端通过Pipeline执行调度模块调用预设搜 索算法检索算法调度表, 确定出当前的待执行节点, 待执行节点为步骤103中创建的有向无 环图中的节点, 待执行节点上加载有人工智能算法。 在减少带宽利用率的情况下, 将待执行 节点的相关的信息索引传递到步骤101创建的有向图中的节点上。 步骤101创建的有向图中 包括的节点数目与异构芯片中集成的人工智能引擎的数目相同, 本申请实施例首次通过上 述方式确定待执行节点时, 可以将执行顺序排在最前面的若干节点确定为。
31、待执行节点, 确 说明书 5/9 页 8 CN 111399911 A 8 定的待执行节点的数目与步骤101创建的有向图中包括的节点数目相同, 然后将确定的各 个待执行节点分别映射到有向图的不同节点上, 如此有向图的每个节点都映射了有向无环 图中的待执行节点, 后续通过有向图中的各个节点上加载的多个人工智能引擎并行执行多 个待执行节点, 提高了人工智能程序执行的效率。 0072 若有向图某个节点上的待执行节点运行结束, 则根据该待执行节点对应的数据流 向信息将执行结果传输给下一节点。 其中, 有向图当前节点上映射的待执行节点对应的人 工智能算法的输出将作为该下一节点上映射的待执行节点对应的人工。
32、智能算法的输入。 0073 按照上述方式将人工智能算法对应的有向无环图映射到异构芯片对应的有向图 中, 依据算法调度表通过动态调度有向无环图, 将有向无环图的节点映射到对应的人工智 能引擎上完成数据的计算与计算结果的获取。 0074 本申请实施例将异构芯片中集成的多个人工智能引擎抽象为有向图, 将用户开发 的多个人工智能算法及各个人工智能算法之间的数据流向抽象为有向无环图。 通过异构芯 片对应的有向图每个节点上加载的人工智能引擎并行执行有向无环图的节点上加载的人 工智能算法, 提高了人工智能引擎的利用率, 增加了人工智能芯片的算力, 简化了人工智能 程序开发的难度。 0075 本申请实施例提供。
33、了一种基于多核异构计算的人工智能开发装置, 该装置用于执 行上述实施例所述的基于多核异构计算的人工智能开发方法。 参见图4, 该装置包括: 0076 有向图创建模块401, 用于创建异构芯片的架构模式对应的有向图; 0077 有向无环图创建模块402, 用于根据用户提交的多个人工智能算法及算法数据流 向信息, 创建人工智能算法对应的有向无环图; 0078 调度表生成模块403, 用于根据有向无环图, 生成对应的算法调度表; 0079 异构运算模块404, 用于根据算法调度表, 通过有向图对有向无环图中的多个人工 智能算法进行运算处理。 0080 上述有向图创建模块401, 具体用于确定异构芯片。
34、的架构模式中包含的人工智能 引擎的数目; 创建数目个节点, 且将任意两个节点之间相互连接; 将异构芯片中的各个人工 智能引擎分别加载到创建的不同节点上, 得到异构芯片的架构模式对应的有向图。 0081 上述有向无环图创建模块402, 具体用于根据用户提交的人工智能算法的数目, 创 建该数目个节点; 将用户提交的各个人工智能算法分别加载到创建的不同节点上; 根据用 户提交的用于指示各个人工智能算法之间数据流向的算法数据流向信息, 确定创建的节点 之间的连接关系, 得到人工智能算法对应的有向无环图。 0082 上述调度表生成模块403, 具体用于对有向无环图中的节点进行拓扑排序, 确定有 向无环图。
35、中各节点的执行顺序及每个节点的数据流向信息; 根据各节点的执行顺序及每个 节点的数据流向信息, 生成有向无环图对应的算法调度表。 0083 该装置还包括: 校验模块, 用于通过预设校验算法校验有向无环图中是否包含数 据环路; 若有向无环图中不包含数据环路, 则执行调度表生成模块403的操作; 若有向无环 图中包含数据环路, 则显示用于指示多个人工智能算法中存在逻辑错误的报错信息。 0084 上述异构运算模块404, 具体用于调用预设搜索算法从算法调度表中确定出当前 的待执行节点及其对应的数据流向信息; 将有向无环图中待执行节点上加载的人工智能算 法映射到有向图的节点上; 通过有向图的节点上加载。
36、的人工智能引擎执行映射的人工智能 说明书 6/9 页 9 CN 111399911 A 9 算法, 并将执行结果传输给数据流向信息对应的下一节点。 0085 本申请实施例提供的基于多核异构计算的人工智能开发装置与本申请实施例提 供的基于多核异构计算的人工智能开发方法出于相同的发明构思, 具有与其采用、 运行或 实现的相同的有益效果。 0086 本申请实施方式还提供一种与前述实施方式所提供的基于多核异构计算的人工 智能开发方法对应的电子设备, 以执行上述方法。 0087 请参考图5, 其示出了本申请的一些实施方式所提供的一种电子设备的示意图。 如 图5所示, 所述电子设备2包括: 处理器200,。
37、 存储器201, 总线202和通信接口203, 所述处理器 200、 通信接口203和存储器201通过总线202连接; 所述存储器201中存储有可在所述处理器 200上运行的计算机程序, 所述处理器200运行所述计算机程序时执行本申请前述任一实施 方式所提供的基于多核异构计算的人工智能开发方法。 0088 其中, 存储器201可能包含高速随机存取存储器(RAM: Random Access Memory), 也 可能还包括非不稳定的存储器(non-volatile memory), 例如至少一个磁盘存储器。 通过至 少一个通信接口203(可以是有线或者无线)实现该系统网元与至少一个其他网元之间。
38、的通 信连接, 可以使用互联网、 广域网、 本地网、 城域网等。 0089 总线202可以是ISA总线、 PCI总线或EISA总线等。 所述总线可以分为地址总线、 数 据总线、 控制总线等。 其中, 存储器201用于存储程序, 所述处理器200在接收到执行指令后, 执行所述程序, 前述本申请实施例任一实施方式揭示的所述基于多核异构计算的人工智能 开发方法可以应用于处理器200中, 或者由处理器200实现。 0090 处理器200可能是一种集成电路芯片, 具有信号的处理能力。 在实现过程中, 上述 方法的各步骤可以通过处理器200中的硬件的集成逻辑电路或者软件形式的指令完成。 上 述的处理器20。
39、0可以是通用处理器, 包括中央处理器(Central Processing Unit, 简称 CPU)、 网络处理器(Network Processor, 简称NP)等; 还可以是数字信号处理器(DSP)、 专用 集成电路(ASIC)、 现成可编程门阵列(FPGA)或者其他可编程逻辑器件、 分立门或者晶体管 逻辑器件、 分立硬件组件。 可以实现或者执行本申请实施例中的公开的各方法、 步骤及逻辑 框图。 通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。 结合本申 请实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成, 或者用译码处理 器中的硬件及软件模块组合执行完成。 。
40、软件模块可以位于随机存储器, 闪存、 只读存储器, 可编程只读存储器或者电可擦写可编程存储器、 寄存器等本领域成熟的存储介质中。 该存 储介质位于存储器201, 处理器200读取存储器201中的信息, 结合其硬件完成上述方法的步 骤。 0091 本申请实施例提供的电子设备与本申请实施例提供的基于多核异构计算的人工 智能开发方法出于相同的发明构思, 具有与其采用、 运行或实现的方法相同的有益效果。 0092 本申请实施方式还提供一种与前述实施方式所提供的的基于多核异构计算的人 工智能开发方法对应的计算机可读存储介质, 请参考图6, 其示出的计算机可读存储介质为 光盘30, 其上存储有计算机程序(。
41、即程序产品), 所述计算机程序在被处理器运行时, 会执行 前述任意实施方式所提供的基于多核异构计算的人工智能开发方法。 0093 需要说明的是, 所述计算机可读存储介质的例子还可以包括, 但不限于相变内存 (PRAM)、 静态随机存取存储器(SRAM)、 动态随机存取存储器(DRAM)、 其他类型的随机存取存 说明书 7/9 页 10 CN 111399911 A 10 储器(RAM)、 只读存储器(ROM)、 电可擦除可编程只读存储器(EEPROM)、 快闪记忆体或其他光 学、 磁性存储介质, 在此不再一一赘述。 0094 本申请的上述实施例提供的计算机可读存储介质与本申请实施例提供的基于多。
42、 核异构计算的人工智能开发方法出于相同的发明构思, 具有与其存储的应用程序所采用、 运行或实现的方法相同的有益效果。 0095 需要说明的是: 0096 在此提供的算法和显示不与任何特定计算机、 虚拟装置或者其它设备有固有相 关。 各种通用装置也可以与基于在此的示教一起使用。 根据上面的描述, 构造这类装置所要 求的结构是显而易见的。 此外, 本申请也不针对任何特定编程语言。 应当明白, 可以利用各 种编程语言实现在此描述的本申请的内容, 并且上面对特定语言所做的描述是为了披露本 申请的最佳实施方式。 0097 在此处所提供的说明书中, 说明了大量具体细节。 然而, 能够理解, 本申请的实施 。
43、例可以在没有这些具体细节的情况下实践。 在一些实例中, 并未详细示出公知的方法、 结构 和技术, 以便不模糊对本说明书的理解。 0098 类似地, 应当理解, 为了精简本申请并帮助理解各个发明方面中的一个或多个, 在 上面对本申请的示例性实施例的描述中, 本申请的各个特征有时被一起分组到单个实施 例、 图、 或者对其的描述中。 然而, 并不应将该公开的方法解释成反映如下意图: 即所要求保 护的本申请要求比在每个权利要求中所明确记载的特征更多的特征。 更确切地说, 如下面 的权利要求书所反映的那样, 发明方面在于少于前面公开的单个实施例的所有特征。 因此, 遵循具体实施方式的权利要求书由此明确地。
44、并入该具体实施方式, 其中每个权利要求本身 都作为本申请的单独实施例。 0099 本领域那些技术人员可以理解, 可以对实施例中的设备中的模块进行自适应性地 改变并且把它们设置在与该实施例不同的一个或多个设备中。 可以把实施例中的模块或单 元或组件组合成一个模块或单元或组件, 以及此外可以把它们分成多个子模块或子单元或 子组件。 除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外, 可以采用任何 组合对本说明书(包括伴随的权利要求、 摘要和附图)中公开的所有特征以及如此公开的任 何方法或者设备的所有过程或单元进行组合。 除非另外明确陈述, 本说明书(包括伴随的权 利要求、 摘要和附图)中。
45、公开的每个特征可以由提供相同、 等同或相似目的的替代特征来代 替。 0100 此外, 本领域的技术人员能够理解, 尽管在此所述的一些实施例包括其它实施例 中所包括的某些特征而不是其它特征, 但是不同实施例的特征的组合意味着处于本申请的 范围之内并且形成不同的实施例。 例如, 在下面的权利要求书中, 所要求保护的实施例的任 意之一都可以以任意的组合方式来使用。 0101 本申请的各个部件实施例可以以硬件实现, 或者以在一个或者多个处理器上运行 的软件模块实现, 或者以它们的组合实现。 本领域的技术人员应当理解, 可以在实践中使用 微处理器或者数字信号处理器(DSP)来实现根据本申请实施例的虚拟机。
46、的创建装置中的一 些或者全部部件的一些或者全部功能。 本申请还可以实现为用于执行这里所描述的方法的 一部分或者全部的设备或者装置程序(例如, 计算机程序和计算机程序产品)。 这样的实现 本申请的程序可以存储在计算机可读介质上, 或者可以具有一个或者多个信号的形式。 这 说明书 8/9 页 11 CN 111399911 A 11 样的信号可以从因特网网站上下载得到, 或者在载体信号上提供, 或者以任何其他形式提 供。 0102 以上所述, 仅为本申请较佳的具体实施方式, 但本申请的保护范围并不局限于此, 任何熟悉本技术领域的技术人员在本申请揭露的技术范围内, 可轻易想到的变化或替换, 都应涵盖在本申请的保护范围之内。 因此, 本申请的保护范围应以所述权利要求的保护范 围为准。 说明书 9/9 页 12 CN 111399911 A 12 图1 图2 说明书附图 1/3 页 13 CN 111399911 A 13 图3 图4 说明书附图 2/3 页 14 CN 111399911 A 14 图5 图6 说明书附图 3/3 页 15 CN 111399911 A 15 。
- 内容关键字: 基于 多核 计算 人工智能 开发 方法 装置
纳米气泡布面除油预缩设备.pdf
半导体老化冷热测试装置.pdf
RFID芯片剪切力测试仪.pdf
可按摩式颈托睡眠头枕及汽车座椅.pdf
汽车点火装饰圈.pdf
起落架部件机加工同心度辅助工装.pdf
园林绿化垃圾处理装置.pdf
施工物料分筛装置.pdf
鸡粪螺旋挤出设备.pdf
用于分砖的压砖装置.pdf
故障电池包防护箱.pdf
耐磨型泥沙挖掘齿.pdf
阀门锁盖设备.pdf
用于多肽固相合成的后处理系统及多肽固相合成设备.pdf
高压线圈导线拉紧装置.pdf
可调式带锯机切割辅助工装.pdf
温度压力一体化检测的波码通信控制装置.pdf
屋面防水卷材辅助施工设备.pdf
桥梁支座变形角度测量装置.pdf
便于冷却烘干的塑料玩具注塑机.pdf
防护插板.pdf
基于特征融合Transformer的多对比度核磁共振图像超分辨率方法.pdf
复叠制冷压缩机组.pdf
盾构管片拼装定位分体测量装置.pdf
自组装多肽RAKA 16的合成方法.pdf
基于机器学习的盾构掘进机姿态分项预测方法.pdf
宫颈TCT切片的多类型细胞核标注及多任务处理方法.pdf
基于自然资源工程勘测面积的测量装置.pdf
数据处理方法、装置及电子设备.pdf
基于人工智能的生物质电厂燃烧控制决策优化方法及系统.pdf
低功率的医院污水处理装置.pdf
基于FV-MViT的指静脉识别方法、装置及相关介质.pdf
自动启动的排风扇.pdf
设有凹腔的侧入式背光模组及屏下指纹识别装置.pdf
交流盘形悬式瓷绝缘子.pdf
具有升降功能的计算机网络设备箱.pdf
翻译软件.pdf
方便使用的等离子切割机.pdf
发酵液粘度实时监测装置.pdf
自动控制运行的炭化炉.pdf
用于糖化血红蛋白分析仪自动进样的指尖采血器.pdf
绝缘清障工具.pdf
声级计自动校准装置.pdf
匀整装置.pdf
电梯的应急救援方法及装置.pdf
网约农机平台.pdf
热交换台和应用其的晶硅铸锭炉.pdf
电磁炉线圈盘的控制装置.pdf
竹条竹青竹黄面自动识别及翻转设备.pdf
具有抗震功能的水阀.pdf
猕猴桃魔芋固体饮料及其制备方法.pdf