数据流的时空映射方法、装置、电子设备及存储介质与流程

未命名 08-03 阅读:116 评论:0


1.本发明实施例涉及人工智能芯片架构的建模测试技术,尤其涉及一种数据流的时空映射方法、装置、电子设备及存储介质。


背景技术:

2.在进行ai(artificial intelligence,人工智能)芯片的架构探索时,对于给定的多个数据流任务以及特定的某种架构,我们需要通过基准测试评估这些数据流任务在该架构上的执行情况。在进行基准测试建模时,通常需要对特定架构和数据流任务进行比较复杂的建模,然后进行仿真,整体的开发代价和周期都较大。
3.因此,如何能在进行基准测试之前构建得到有效的建模参考信息,为后续进行灵活性、可扩展性的基准测试建模提供高效可用的数据准备,是目前有待解决的重要问题。


技术实现要素:

4.本发明实施例提供一种数据流的时空映射方法、装置、电子设备及存储介质,以准确、高效的将数据流任务在时间维度和空间维度进行双重映射,为后续进行基准测试建模提供高效可用的数据准备。
5.第一方面,本发明实施例提供了一种数据流的时空映射方法,该方法包括:
6.获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;
7.根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;
8.根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
9.第二方面,本发明实施例还提供了一种数据流的时空映射装置,该装置包括:
10.目标数据流获取模块,用于获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;
11.时域映射模块,用于根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;
12.空域映射模块,用于根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
13.第三方面,本发明实施例还提供了一种电子设备,所述电子设备包括:
14.至少一个处理器;以及
15.与所述至少一个处理器通信连接的存储器;其中,
16.所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行如本发明任一实施例所述的数据流的时空映射方法。
17.第四方面,本发明实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现如本发明任一实施例所述的数据流的时空映射方法。
18.本发明实施例的技术方案通过获取待时空映射的目标数据流;根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中的技术手段,实现了在架构和时间两个维度下,对数据流任务进行了简化和抽象,能够清晰的规划出数据流任务在一段时间内,在架构的不同子系统中的执行情况,为后续进行灵活性、可扩展性的基准测试建模提供高效可用的数据准备,从一定程度上可以减低基准测试建模的开发代价和周期。
附图说明
19.图1是根据本发明实施例一提供的一种数据流的时空映射方法的流程图;
20.图2是根据本发明实施例二提供的一种数据流的时空映射方法的流程图;
21.图3是本发明实施例二的方法所适用的一种子数据流在目标架构中每个层级下的时间映射结果的示意图;
22.图4是根据本发明实施例三提供的一种数据流的时空映射方法的流程图;
23.图5是本发明实施例三的方法所适用的一种子数据流的数据流路径的时间偏移处理结果的示意图;
24.图6是根据本发明实施例四提供的一种数据流的时空映射方法的流程图;
25.图7是本发明实施例四的方法所适用的一种多个子数据流的时空映射结果示意图;
26.图8是本发明实施例四的方法所适用的一种对多个子数据流的数据流路径进行重排布后的时空映射结果示意图;
27.图9是本发明实施例四的方法所适用的一种通过执行顺序检查规则的多个子数据流的时空映射结果示意图;
28.图10是本发明实施例四的方法所适用的另一种通过执行顺序检查规则的多个子数据流的时空映射结果示意图;
29.图11是根据本发明实施例五提供的一种数据流的时空映射方法的流程图;
30.图12是本发明实施例五的方法所适用的一种将与各子数据流分别对应的数据流路径在统一时间线上进行排布后的时空映射结果示意图;
31.图13是本发明实施例五的方法所适用的另一种将与各子数据流分别对应的数据流路径在统一时间线上进行排布后的时空映射结果示意图;
32.图14是本发明实施例五的方法所适用的再一种将与各子数据流分别对应的数据流路径在统一时间线上进行排布后的时空映射结果示意图;
33.图15是根据本发明实施例六提供的一种数据流的时空映射装置的结构示意图;
34.图16是实现本发明实施例的数据流的时空映射方法的电子设备的结构示意图。
具体实施方式
35.下面结合附图和实施例对本发明作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释本发明,而非对本发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本发明相关的部分而非全部结构。
36.实施例一
37.图1为本发明实施例一提供的一种数据流的时空映射方法的流程图,本实施例可适用于将数据流任务在时间维度和空间维度进行双重映射的情况,该方法可以由数据流的时空映射装置来执行,该装置可以通过软件和/或硬件的方式实现,并一般可以集成在具有数据处理功能的计算机设备中,
38.相应的,如图1所示,该方法具体包括如下步骤:
39.s110、获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务。
40.其中,目标架构是指待进行架构探索的ai架构,可以理解为一个用于处理负载任务的硬件资源集合。目标架构可以为一个已有的硬件实体架构,也可以为一个处于开发阶段的自定义软件实现架构等,目标架构中包括的硬件资源集合中可以全部为同构硬件资源,也可以为异构硬件资源等,本实施例对此并不进行限制。
41.具体的,该目标架构中可以包括有一个或者多个硬件子系统,不同子系统在该目标架构中具有设定的拓扑连接关系,以构成设定的层级架构。其中,每个子系统用于实现设定的子系统功能。例如,计算功能、编解码功能或者存储功能等。
42.在本实施例中,该目标架构可以通过子系统定义和子系统规格进行描述,上述两种信息可以统称为目标架构的架构定义信息。在该子系统定义中可以包含有下述信息:目标架构中包含的子系统层级、子系统例化数目、各子系统的标识信息,每个子系统与其他子系统之间的拓扑连接关系、子系统功能以及每个子系统内功能模块的例化数目,例如计算子系统中包括有多个计算单元作为功能模块。同时,针对每个子系统,分别通过子系统规格进行描述。不同功能类型的子系统,其子系统规格一般不同。
43.在一个具体的例子中,针对实现计算核计算的子系统,其子系统规格中一般包含:微架构类型,最高频率,向量计算算力,张量计算算力,张量计算形状,读、写带宽以及读、写端口数目;针对实现片内存储功能的子系统,其子系统规格中一般包含:微架构类型,存储容量,与其相连的子系统的读、写带宽,以及与其相连的子系统的读、写端口数目;针对实现片外存储功能的子系统,其子系统规格中一般包含:微架构类型,存储容量,与其相连的子系统的读、写带宽以及与其相连的子系统的读、写端口数目;针对实现子系统间互联功能的子系统,其子系统规格中一般包含:微架构类型,连接的子系统层级,读、写带宽以及读、写
端口数目;针对实现子系统内互联功能的子系统,其子系统规格中一般包含:微架构类型,子系统类型,读、写带宽以及读、写端口数目等。
44.需要说明的是,针对硬件实体架构,该例化数目可以理解为该硬件实体架构中实际包含的数目,针对自定义软件实现架构,该例化数目可以理解为软件仿真得到的数目。
45.在本实施例中,负载任务可以理解为需要加载至目标架构中执行基准测试的任务,也即,该负载任务可以由目标架构执行,以实现一项或者多项负载功能。具体的,该负载任务可以为计算任务、存储任务或者编解码任务等实现单一功能类型的任务,还可以为多个单一功能类型的任务组合构成的多功能类型复合任务等,本实施例对此并不进行限制。
46.在本实施例中,测试人员可以根据实际的架构探索需求,自定义设置该负载任务,以满足实际的建模评估需求。具体的,该负载任务可以按照预设的拆分规则拆分为一个或者多个子任务。例如,如果该负载任务为基于设定计算图的计算任务,则可以按照计算图中包括的各个计算算子,将负载任务拆分为多个子任务,或者,还可以首先分析该负载任务中包含的功能类型数量,并以功能类型为单位,将负载任务拆分为多个子任务,或者,还可以首先评估该负载任务所需的硬件资源总数量,并基于该硬件资源总数量以及预设的子任务划分数量,预估每个子任务所需的平均硬件资源数量,并基于该平均硬件资源数量,将负载任务拆分为多个子任务等,本实施例对此并不进行限制。
47.在本实施例的一个可选的实施方式中,可以初始化构建得到负载任务中各子任务的原始负载描述信息,进而,可以通过解析各子任务的原始负载描述信息的方式,简单、便捷的将该负载任务拆分为多个子任务。
48.可选的,各子任务的原始负载描述信息中可以包括:每个子任务的所属任务名称、域描述信息、操作数描述信息以及操作数访问类型,以及各子任务之间的依赖关系描述信息等。
49.其中,域描述信息中包含子任务本身所包含的数据维度以及操作数的形状描述信息;操作数描述信息中包含操作数名称、操作数域描述信息以及操作数的数据精度;操作数访问类型中包含读或者写等计算类型,依赖关系描述信息中包含子任务与其他子任务的显示依赖关系。
50.进一步的,原始负载描述信息中需要指定每个子任务的需求资源类型,也即,该需求资源类型定义一个子任务需要配置在何种功能类型的硬件资源(子系统)中执行。
51.其中,可以使用预先构建的一个或者多个映射策略,将某一个具体的子任务映射至目标架构中的某一个具体的子系统中。上述映射策略可以规定某些子任务可以被分配到多个运算资源上,某些子任务只由单个运算资源执行,多个子任务可以分配到同样的运算资源上,依序执行,以及异构任务需要根据其指定的架构资源,依序分配到特定的异构架构上等。
52.当然,可以理解的是,除了可以使用上述预先构建的一个或者多个映射策略,还可以通过预留人工干预接口的方式,由测试人员手动加入自定义的映射策略,例如,数据并行映射策略、模型并行映射策略或者流水并行映射策略等,以满足测试人员对某一特定方向的映射效果的意图探究。
53.相应的,在生成负载任务中各子任务与目标架构中各子系统之间的任务架构映射关系之后,还可以根据每个子任务的数据维度描述信息和该任务架构映射关系,确定与各
子任务分别对应的至少一个数据流。
54.其中,数据流中包括:子任务中各数据维度的执行顺序、并行维度、子任务中各数据维度的切片大小,以及子任务中各数据维度在目标架构的每级缓冲区或每级缓存中的存储策略。
55.可选的,在获取负载任务中各子任务与目标架构中各子系统之间的任务架构映射关系之后,通过结合每个子任务的数据维度描述信息,可以生成与每个子任务分别对应的一个或者多个数据流。
56.其中,该数据维度描述信息可以包括子任务本身所包含的数据维度以及操作数的形状描述信息,例如,针对一个矩阵乘的子任务,与其对应的数据维度描述信息可以为[m,n,k]。可选的,可以在子任务的原始负载描述信息中提取域描述信息,并将该域描述信息作为数据维度描述信息。
[0057]
其中,子任务中各数据维度的执行顺序可以理解为子任务在单个硬件计算单元(在一个具体的例子中,该硬件计算单元可以为通用可扩展神经元处理器,简称为sip)上的数据移动顺序。该数据移动顺序可以理解为取操作数的顺序或者操作数的搬运顺序。可以理解的是,如果子任务中包括多个数据维度,上述各数据维度的搬运过程对应一个多层级的循环搬运过程,上述各数据维度的执行顺序决定了哪个数据维度为上述循环过程中的外层循环变量,哪个数据维度为上述循环过程中的内层循环变量。
[0058]
不同的数据维度执行顺序一般对应不同的数据搬运效率。可选地,可以根据每个数据维度的数据量,例如,m、n以及k的具体取值,以及每个数据维度在实际计算过程中的数据属性,例如,是否为规约(reduce)维度等,确定出子任务中各数据维度的执行顺序。
[0059]
并行维度可以理解为子任务本身所包含的各数据维度中,能够分配到不同硬件计算单元上进行并行计算的维度。可选地,可以根据每个数据维度的数据量以及子系统中包括的可用硬件计算单元的数目,计算得到每个数据维度在硬件计算单元上的执行次数,并基于上述执行次数计算结果,确定出最适宜的并行维度。
[0060]
子任务中各数据维度的切片大小,可以理解为每个硬件计算单元中所能计算的最小数据量,该切片大小可以由目标架构中架构定义信息确定。
[0061]
子任务中各数据维度在目标架构的每级缓冲区中的存储策略,可以理解为子任务的每个数据维度在目标架构中的各个缓冲区存储层级上的存储状态。子任务中各数据维度在目标架构的每级缓存中的存储策略,可以理解为子任务的每个数据维度在目标架构的每级缓存中的复用信息。可选的,可以通过每个子任务的数据维度描述信息以及目标架构的架构定义信息,构建一个或者多个约束条件,并通过求解线性方程组的方式,确定出子任务中各数据维度在目标架构的每级缓冲区或每级缓存中的存储策略。
[0062]
可以理解的是,目标架构一般会择一选择缓冲区(buffer)存储策略或者缓存(cache)存储策略,进而,数据流中一般仅包括有子任务中各数据维度在目标架构的每级缓冲区中的存储策略,或者,仅包括有子任务中各数据维度在目标架构的每级缓存中的存储策略。
[0063]
在本实施例中,以与负载任务中的一个具体的目标子任务匹配的目标数据流为例,描述如何对该目标数据流进行时空映射。
[0064]
s120、根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,
并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流。
[0065]
一般来说,目标子任务无法通过单次数据搬运完成任务的实施,具体的,可能涉及多次将不同存储位置的数据搬运至一个或者多个硬件计算单元中分别实施计算,或者将一个或者多个硬件计算单元的计算结果搬运至设定存储空间的情况。通过解析目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,可以确定出与该目标子任务匹配的多个具有时序关系的数据搬运操作,并确定出与每个数据搬运操作对应的数据搬运对象(例如,存储单元l1中存储的,操作数形状为[m,n]的操作数a的一个切片大小a*b的一个数据切片,或者,硬件计算单元中当前计算得到的形状为[k,g]的计算结果数据),以及数据搬运方向(例如,从存储单元搬运至硬件计算单元,或者从硬件计算单元搬运至设定存储单元)。
[0066]
进而,可以将目标数据流拆分得到多个子数据流,每个子数据流对应一个数据搬运操作,也即,在何种数据搬运方向下,对何种数据搬运对象实施数据搬运。
[0067]
可以理解的是,与目标数据流对应的多个数据搬运操作在时间维度上是具有先后顺序的,例如,操作数a共对应两个数据切片a1和a2,则数据切片a1的数据搬运操作1的执行时间需要先于数据切片a2的数据搬运操作2。相应的,如果数据搬运操作1对应子数据流1,数据搬运操作2对应子数据流2,则上述两个子数据流的时域执行先后顺序为:子数据流1,子数据流2。可以理解的是,一个子数据流对应一个时间片,时间片可以理解为一个子数据流的执行时间段。一般来说,不同子数据流对应的时间片之间,具有时域先后顺序。
[0068]
s130、根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
[0069]
在本实施例中,需要预先建立负载任务中各子任务与目标架构中各子系统之间的任务架构映射关系。其中,负载任务中各子任务与目标架构中各子系统之间的任务架构映射关系用于描述负载任务中的哪个子任务需要映射至目标架构中的哪个子系统中执行基准测试仿真。
[0070]
其中,可以使用预先构建的一个或者多个映射策略,将某一个具体的子任务映射至目标架构中的某一个具体的子系统中。上述映射策略可以规定某些子任务可以被分配到多个运算资源上,某些子任务只由单个运算资源执行,多个子任务可以分配到同样的运算资源上,依序执行,以及异构任务需要根据其指定的架构资源,依序分配到特定的异构架构上等。
[0071]
当然,可以理解的是,除了可以使用上述预先构建的一个或者多个映射策略,还可以通过预留人工干预接口的方式,由测试人员手动加入自定义的映射策略,例如,数据并行映射策略、模型并行映射策略或者流水并行映射策略等,以满足测试人员对某一特定方向的映射效果的意图探究。
[0072]
在一个具体的示例中,如果子任务s通过架构映射,被映射至计算单元sip[2]中,则可以构建形如:s-》sip[2]的表达式,其表明子任务s中包括的各项操作数需要最终搬运至计算单元sip[2]中实施计算。
[0073]
在本实施例中,目标架构中定义的各子系统的连接关系可以理解为目标架构中各
子系统之间的层级架构关系。例如,在目标架构中,包括有l2存储单元、l1存储单元以及多个计算单元(sip或者computer)作为子系统,l2存储单元与l1存储单元直接相连,l1存储单元与各计算单元直接相连,则上述各子系统按照从上层到下层的层级架构关系可以为:l2-》l1-》sip(或者computer)。
[0074]
相应的,在获取了目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系后,可以确定出每个子数据流对应的搬运数据在目标架构中的流转方式。例如,如果目标子任务映射至计算单元sip[n]中,且确定目标架构中定义的各子系统的连接关系为l2-》l1-》sip,则可以确定目标子任务的子数据流x对应的搬运数据需要从l2存储空间的设定存储地址中搬运至l1存储空间的设定存储地址后,再由l1存储空间的设定存储地址处,搬运至标识为n的sip中实施计算。进而,可以将在不同时间片下执行的不同子数据流分别映射至目标架构各层级的子系统中。
[0075]
在本实施例中,在将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中之后,可以将最终得到的时空映射结果作为该基准测试中的一项建模参考信息,为将负载任务配置在目标架构上执行基准测试时的系统建模和架构评估提供高效、可用的数据准备。
[0076]
本发明实施例的技术方案通过获取待时空映射的目标数据流;根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中的技术手段,实现了在架构和时间两个维度下,对数据流任务进行了简化和抽象,能够清晰的规划出数据流任务在一段时间内,在架构不同子系统中的执行情况,为后续进行灵活性、可扩展性的基准测试建模提供高效可用的数据准备,从一定程度上可以减低基准测试建模的开发代价和周期。
[0077]
实施例二
[0078]
图2是本发明实施例二提供的一种数据流的时空映射方法的流程图,本实施例以上述各实施例为基础进行优化,在本实施例中,将针对数据流的时空映射方式进行具体化。
[0079]
相应的,如图2所示,所述方法具体可以包括:
[0080]
s210、获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务。
[0081]
s220、根据目标数据流中包括的目标子任务中各数据维度的执行顺序,并行维度和和目标子任务中各数据维度的切片大小,将目标数据流拆分为多个子数据流,并确定每个子数据流的执行顺序。
[0082]
如前所述,在获取目标数据流中包括的目标子任务中各数据维度的执行顺序,并行维度和和目标子任务中各数据维度的切片大小之后,可以将目标子任务拆分为基于多个数据搬运操作的计算过程,进而,可以生成与每个数据搬运操作分别对应的子数据流。
[0083]
相应的,不同数据搬运操作之间的时域关系,决定了每个子数据流的执行顺序。
[0084]
s230、按照各子数据流的执行顺序,并将各子数据流在多个连续时间片上进行顺序排布。
[0085]
其中,一个时间片对应一个时间区间。相应的,可以建立时间轴,并在该时间轴上,创建多个连续时间片。在初始化阶段,各时间片的起止时间点可以不在该时间轴上被赋值,仅指定每个时间片的所占用的时间间隔即可。当基准测试的启动时间点被确定后,上述各时间片的起止时间点将被唯一相应确定。
[0086]
在一个具体的例子中,如果将目标数据流拆分为子数据流1和子数据流2,且子数据流1的时域执行时间先于子数据流2的时域执行区间。进而,可以在上述时间轴中,沿时间延伸顺序建立两个相邻的时间片1和时间片2后,将子数据流1排布在时间片1上,并将子数据流2排布在时间片2上。
[0087]
s240、获取与目标子任务具有架构映射关系的目标子系统,并根据目标子系统和目标架构中定义的各子系统的连接关系,确定出与设定时间片下执行的每个子数据流分别对应的数据流路径。
[0088]
其中,数据流路径由多个相邻层级的子系统串联构成,且该数据流路径的起始路径点或终止路径点为目标子系统。
[0089]
在本实施例中,通过查询预先建立的子任务和子系统之间的架构映射关系,可以获取与目标子任务匹配的目标子系统。可以理解的是,与一个子数据流匹配的数据搬运操作可以为将设定层级的存储空间中存储的操作数搬运至目标子系统中实施计算,也可以为将目标子系统计算得到的计算结果搬运至设定层级的存储空间中进行存储。相应的,可以确定该目标子系统为每个子数据流的数据流转起点或者数据流转终点。其中,在获取目标子系统后,结合与目标子任务对应的各操作数在目标架构中的存储位置,以及目标架构中定义的各子系统的连接关系,可以确定出与每个数据流分别对应的数据流路径。同时,每个数据流对应一个时间片,一个时间片可以理解为一个数据流的执行时间区间。
[0090]
其中,在图3中示出了本发明实施例所适用的一种子数据流在目标架构中每个层级下的时间映射结果的示意图。如图3所示,子数据流1实现了在时间维度(time)和空间架构维度(arch)下的双重映射。具体的,在时间维度下,子数据流被映射至时间片t[a]下执行,在空间架构维度,假设arch[a]为l2存储单元,arch[b]为l1存储单元,arch[c]为计算单元,则子数据流可以映射为从l2中的一个存储区域data[id]-》l1中的一个存储区域data[id]
ꢀ‑
》计算单元中的一个具体的计算单元computer[id]的数据流路径。其中,与目标子任务具有架构映射关系的目标子系统为computer[id]。
[0091]
本发明实施例的技术方案通过根据目标数据流中包括的目标子任务中各数据维度的执行顺序,并行维度和和目标子任务中各数据维度的切片大小,将目标数据流拆分为多个子数据流,并确定每个子数据流的执行顺序;按照各子数据流的执行顺序,并将各子数据流在多个连续时间片上进行顺序排布;获取与目标子任务具有架构映射关系的目标子系统,并根据目标子系统和目标架构中定义的各子系统的连接关系,确定出与设定时间片下执行的每个子数据流分别对应的数据流路径的具体实现方式,可以简单、高效且准确的实现数据流的时空映射,以辅助提高架构评估的效率。
[0092]
实施例三
[0093]
图4是本发明实施例三提供的一种数据流的时空映射方法的流程图,本实施例以上述各实施例为基础进行优化,在本实施例中,在确定出与设定时间片下执行的每个子数据流分别对应的数据流路径的操作之后,还具体包括:在全部子数据流中,获取与目标时间
片对应的目标子数据流;获取与目标子数据流匹配的目标数据流路径,并计算目标数据流路径中包括的路径点数量;以目标时间片为起点,获取与路径点数量匹配的连续时间片集合;将目标数据流路径中包括的各路径点顺序映射至连续时间片集合中的各时间片中;返回执行在全部子数据流中,获取与目标时间片对应的目标子数据流的操作,直至完成对全部子数据流的数据流路径的时间偏移处理。
[0094]
相应的,如图4所示,所述方法具体包括:
[0095]
s410、获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务。
[0096]
s420、根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流。
[0097]
s430、根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中。
[0098]
s440、在全部子数据流中,获取与目标时间片对应的目标子数据流。
[0099]
如前所述,在对目标数据流进行拆分的过程中,一般可以拆分得到多个子数据流。每个子数据流被映射至一个特定的时间片上,在本实施例中,以与目标时间片对应的目标子数据流为例,描述针对目标子数据流的时间偏移处理。
[0100]
可以理解的是,一般需要按照各时间片的时间延伸顺序,依次选取各目标子数据流进行时间偏移处理。
[0101]
s450、获取与目标子数据流匹配的目标数据流路径,并计算目标数据流路径中包括的路径点数量。
[0102]
如前所述,数据流路径中包括由多个相邻层级的子系统串联构成,该数据流路径表明了目标子数据流在目标架构中的流转过程。目标数据流路径中以子系统为路径点,通过统计该目标数据流路径中包括的子系统的数量值,可以确定出目标数据流路径中包括的路径点数量。
[0103]
在一个具体的例子中,如果目标数据流路径中包括3个子系统,则目标数据流路径中包括的路径点数量为3。
[0104]
s460、以目标时间片为起点,获取与路径点数量匹配的连续时间片集合。
[0105]
在本实施例中,考虑到目标子数据流在目标架构中的流转过程需要耗费一定的传输时间,因此,考虑加入时间线上的偏移,以体现不同的架构层级间,对于同一个子数据流(包含计算)的时域偏移关系。从而可以更合理地反应负载任务的执行顺序,并反映到之后的时域-空域统计结果中。
[0106]
相应的,可以根据路径点数量,以目标时间片为起点选取多个连续时间片,并将目标数据流路径中的每个路径点,映射至不同的时间片中,以体现上述时域偏移关系。
[0107]
s470、将目标数据流路径中包括的各路径点顺序映射至连续时间片集合中的各时间片中。
[0108]
为了便于说明,在图5示出了一种子数据流的数据流路径的时间偏移处理结果的示意图,该示意图是对图3示例的时空映射后的子数据流1进行的时间偏移处理。同图3示
例,子数据流1的目标数据流路径为:从l2中的一个存储区域data[id]-》l1中的一个存储区域data[id]
ꢀ‑
》计算单元中的一个具体的计算单元computer[id]的目标数据流路径,路径点数量为3,由于子数据流1初始化映射至时间片t[a]中,则需要以t[a]为起点,共获取t[a]、t[b]以及t[c]三个连续时间片,并按照子数据流1的操作数流转顺序,将上述三个路径点分别映射在上述三个时间片上,以实现对目标数据流路径的时间偏移处理。
[0109]
s480、检测是否完成对全部子数据流的数据流路径的时间偏移处理:若是,结束流程;否则,返回执行s440。
[0110]
本实施例的技术方案通过对完成时空映射的各子数据流分别进行时间偏移处理,可以使得最终的时空映射结果更合理地反应负载任务的执行顺序,以进一步提高架构评估的效率。
[0111]
实施例四
[0112]
图6是本发明实施例四提供的一种数据流的时空映射方法的流程图,本实施例以上述各实施例为基础进行优化,在本实施例中,在完成对全部子数据流的时间偏移处理操作后,还可以包括:获取与全部子数据流匹配的时间片起终点范围,并在时间片起终点范围内依次获取当前处理时间片;在每个子数据流的数据流路径中,分别识别与当前时间片匹配的映射路径点;根据至少一个执行顺序检查规则,对各映射路径点进行数据流执行顺序的检查,并在检测到执行顺序异常时,对各子数据流的数据流路径进行重排布,以确保任务执行顺序不被打乱;返回执行在时间片起终点范围内依次获取当前处理时间片的操作,直至完成对时间片起终点范围内全部时间片的数据流执行顺序的检查。
[0113]
s610、获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务。
[0114]
s620、根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流。
[0115]
s630、根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中。
[0116]
s640、对全部子数据流的数据流路径的时间偏移处理后,获取与全部子数据流匹配的时间片起终点范围。
[0117]
其中,在图7中示出了一种在同一时间坐标系下映射多个完成时间偏移处理后的多个子数据流的示意图。具体的,在图7中示出了针对子任务s的多个子数据流,一个s[.]可以理解从一个或者多个操作数从外层存储单元流转至计算单元中实施计算后,重新流转至该外层存储单元中进行数据存储的全流转过程,一般对应两个连续的子数据流。相应的,图7中共包含s[id]、s[id+1]以及s[id+2]三个全流转过程,对应6个子数据流。
[0118]
针对图7的实例,在对全部6个子数据流的数据流路径进行时间偏移处理后,获取与全部子数据流匹配的时间片起终点范围为从t[local a]至t[local f]的6个时间片。
[0119]
s650、在时间片起终点范围内依次获取当前处理时间片。
[0120]
续前例,在确定从t[local a]至t[local f]的时间片起终点范围后,可以依次获取t[local a]、t[local b]、t[local c]、t[local d]、t[local e]以及t[local f]作为当
前处理时间片,以进行数据流执行顺序的检查。
[0121]
s660、在每个子数据流的数据流路径中,分别识别与当前时间片匹配的映射路径点。
[0122]
续前例,如果当前时间片为t[local d]时,则相应的映射路径点为映射至arch[b]的与s[id]对应的data[id]以及与s[id+2]对应的data[id+2],以及,映射至arch[c]的与s[id+1]对应的computer[id+1]。
[0123]
s670、根据至少一个执行顺序检查规则,对各映射路径点进行数据流执行顺序的检查,并在检测到执行顺序异常时,对各子数据流的数据流路径进行重排布,以确保任务执行顺序不被打乱。
[0124]
可选地,该执行顺序检查规则可以包括:缓存空间的限制规则,以及缓存使用策略限制规则,其中,缓存使用策略限制规则包括:替换策略或预取策略。
[0125]
续前例,如果目标架构采用buffer模式进行数据的缓存处理,则在buffer模式下,通常有两种限制规则,第一种是不考虑缓存空间的大小,我们假定缓存的空间无限大,任何数据都能够被存储在其中,那么我们可以将若干个子数据流叠加在一起,按照流水线模式排列。最终所有的子数据流都会被排列在time[id]上。具体的,在如图7所示的目标架构中,arch[b]使用缓存空间无限大的buffer,则在t[local d]的时刻,从arch[a]处获取的存储区域data[id]处的数据1以及存储区域data[id+2]处获取的数据2均可以缓存在该arch[b]的buffer中。
[0126]
第二种限制规则是考虑缓存空间大小,在这种情况下,buffer不能无限存储数据,而是要遵循先进先出的原则,只有头部的数据从buffer中被删掉,新的数据才能够进入到buffer的尾部,此限制规则可以用来精准模拟内存分配(是一种任务创建和管理的常用手段)。所以,需要根据目标架构的架构定义获取buffer的大小。并且我们可以针对不同的操作数(输入,输出),分别定义各自的buffer大小(buffer大小也可以根据不同的存储层级独立定义),以提供更为灵活和全面的buffer分配方式。
[0127]
例如,假设arch[b]的输入、输出都共享一个buffer,且buffer大小是1,那么t[local d]的时刻就不能出现数据1和数据2都进入到arch[b]的buffer中的情况。所以s[id+2]需要进行偏移。这样才能够满足一个时间点上只有一个数据进入到arch[b]的buffer的要求。也即,此时需要对各子数据流的数据流路径进行重排布,以确保任务执行顺序不被打乱。
[0128]
相应的,在图8中示出了本发明实施例的方案所适用的一种对多个子数据流的数据流路径进行重排布后的时空映射结果示意图。如图8所示,通过重排布t[local d]的映射路径点,可以满足arch[b]上的buffer要求。
[0129]
在另一个具体示例中,如果目标架构采用cache模式进行数据的缓存处理。在cache模式下,访问过的数据会被存储在cache中,所以在一定的时间窗口内或者是访问的空间内,数据如果很快再次被访问到,那么就能够从cache中直接获取到数据,而不需要从外层的内存中获取,从而提升了获取数据的速率。而如果原始数据过了很久才被访问,cache中存储的数据已经被替换成别的数据,则无法命中,依然需要从外层的内存中获取。所以,我们需要根据目标架构的架构定义获取复用距离(cache size),当两次访问同一项数据的时间片间隔内其他的数据量总和小于该复用距离时,就可以认为这个数据第二次访
问时能够命中到cache中。
[0130]
在一个具体的例子中,如图9所示,复用距离为4,那么data[id]对应的操作数和data[id+1]对应的操作数以及他们的运算结果都能够被存储在cache中,如果data[id]对应的操作数和data[id]对应的操作数很快再次被用到,那么就可以直接从arch[b]获取到。相应的,图9中示出的时空映射结果通过了复用距离为4时的执行顺序检查规则,满足任务执行顺序要求。
[0131]
在另一个具体的例子中,如图10所示,如果data[id]对应的操作数过了很久才被用到,以至于在这个过程中,cache中的数据被替换成了其他新的数据,那么原始数据再次被读的时候,则无法在cache中被获取到,依然需要从外部内存中获取。此时,如图10所示,需要在新的时间片中重新搬运data[id]对应的操作数到计算单元中进行计算。
[0132]
需要说明的是,对于cache模式,我们还能够计算cache的命中率,同样作为一项基准测试中的一项建模参考信息,以便以后续进行建模分析。
[0133]
其中,cache的命中率=命中在cache的数据量/访问的总数据量*100%。
[0134]
s680、检测是否完成对时间片起终点范围内全部时间片的数据流执行顺序的检查:若是,结束流程;否则,返回执行s650。
[0135]
通过上述设置,可以完全对目标数据流中的全部子数据流的时空映射。
[0136]
本发明实施例的技术方案通过根据至少一个执行顺序检查规则,对各映射路径点进行数据流执行顺序的检查,并在检测到执行顺序异常时,对各子数据流的数据流路径进行重排布的实现方式,可以确保负载任务执行顺序不被打乱,进而使得最终的时空映射结果更合理地反应负载任务的执行顺序,以进一步提高架构评估的效率。
[0137]
实施例五
[0138]
图11是根据本发明实施例五提供的一种数据流的时空映射方法的流程图。本实施例以上述各实施例为基础进行优化,在本实施例中,增加了获取与多个数据流中的各子数据流分别对应的数据流路径;根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布的操作,以及对排布结果进行修正的操作。
[0139]
相应的,如图11所示,所述方法具体可以包括:
[0140]
s1110、获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务。
[0141]
s1120、根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流。
[0142]
s1130、根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中。
[0143]
s1140、对目标数据流的全部子数据流的数据流路径的时间偏移处理后,进行基于执行顺序检查规则的重排布处理。
[0144]
s1150、获取与多个数据流中的各子数据流分别对应的数据流路径。
[0145]
s1160、根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布。
[0146]
在本实施例中,可以预先建立不同数据流之间的依赖关系,可以理解的是,数据流与子任务之间具有一一对应关系,因此,可以通过获取不同子任务之间的依赖关系,作为不同数据流之间的依赖关系。
[0147]
具体的,该依赖关系可以为不同子任务之间的先后执行顺序或者并行处理顺序。其中,该依赖关系可以通过各子任务的输入和输出直接被检测出来,例如,子任务1的输出为y,子任务2的输入为y,输出为z,子任务3的输入为z输出为d,则可以确定子任务3的执行需要依赖子任务2执行完成,子任务2的执行需要依赖子任务1的执行完成,因此,假设子任务1对应数据流1,子任务2对应数据流2,以及子任务3对应数据流3,则数据流1要先于数据流2执行,数据流2要先于数据流3执行。
[0148]
或者,用户还可以根据实际需求显示构建不同子任务之间的关系,例如,强制规定子任务4需要依赖子任务5执行完成等,本实施例对此并不进行限制。
[0149]
在获取不同数据流之间的依赖关系之后,可以确定不同数据流在时域上的先后排布顺序,进而可以将与各子数据流分别对应的数据流路径在统一时间线上进行排布。
[0150]
其中,在图12中示出了一种将两个数据流中的子数据流的数据流路径在统一时间线上进行排布后的时空映射结果示意图。其中,s[id]隶属于与子任务s对应的数据流,s’[id’]隶属于与子任务s’中对应的数据流。
[0151]
s1170、如果多个数据流中存在数据接力节点,则根据数据接力节点所在位置,对排布结果进行修正。
[0152]
其中,在将全部数据流在统一时间线上进行排布后,可以进一步考虑基于数据接力节点对该排布结果进行修正,以进一步提高时空映射结果的精准性。
[0153]
其中,数据接力节点包括数据接力空间节点和/或数据接力时间节点。其中,数据接力空间节点,可以理解为具有依赖关系的两个子任务在目标架构中进行数据交换操作时,该数据交换操作所位于的子系统。该数据接力时间节点可以理解为两个具有逻辑依赖关系的子任务在某一个子系统中实现数据接力操作的时间点。
[0154]
续前例,如果arch[b]是子任务s和子任务s’的数据接力空间节点,则可以在arch[b]对应的时间片t[local d]处,对排布结果进行修正。具体的修正结果如图13所示。
[0155]
s1180、如果多个数据流中存在数据同步关系,则根据数据同步关系所在位置,对排布结果进行修正。
[0156]
在本实施例中,进一步考虑了数据同步关系对排布结果对数据流执行过程的影响。例如,某两个数据流被安排并行执行,测试人员如果要求这两个数据流结束时进行“同步”。那么当其中一个数据流被先执行完时,遇到了“同步”信号就需要进行等待,直到另一个数据流完成,他们才能够同时进行到下一个数据流的处理。
[0157]
其中,在图14中示出了一种引入了数据同步关系后,具体的修正结果示意图。
[0158]
本发明实施例的技术方案通过增加了获取与多个数据流中的各子数据流分别对应的数据流路径;根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布的操作,以及对排布结果进行修正的操作,可以使得最终的时空映射结果更合理地反应负载任务的执行顺序,以进一步提高架构评估的效率。
[0159]
实施例六
[0160]
图15是本发明实施例六提供的一种数据流的时空映射装置的结构示意图。如图15
所示,所述装置包括:目标数据流获取模块1510、时域映射模块1520以及空域映射模块1530。
[0161]
目标数据流获取模块1510,用于获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;
[0162]
时域映射模块1520,用于根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;
[0163]
空域映射模块1530,用于根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
[0164]
本发明实施例的技术方案通过获取待时空映射的目标数据流;根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中的技术手段,实现了在架构和时间两个维度下,对数据流任务进行了简化和抽象,能够清晰的规划出数据流任务在一段时间内,在架构不同子系统中的执行情况,为后续进行灵活性、可扩展性的基准测试建模提供高效可用的数据准备,从一定程度上可以减低基准测试建模的开发代价和周期。
[0165]
在上述各实施例的基础上,时域映射模块1520,可以用于:
[0166]
根据目标数据流中包括的目标子任务中各数据维度的执行顺序,并行维度和和目标子任务中各数据维度的切片大小,将目标数据流拆分为多个子数据流,并确定每个子数据流的执行顺序;
[0167]
按照各子数据流的执行顺序,并将各子数据流在多个连续时间片上进行顺序排布。
[0168]
在上述各实施例的基础上,空域映射模块1530,可以用于:
[0169]
获取与目标子任务具有架构映射关系的目标子系统,并根据目标子系统和目标架构中定义的各子系统的连接关系,确定出与设定时间片下执行的每个子数据流分别对应的数据流路径;
[0170]
其中,数据流路径由多个相邻层级的子系统串联构成,且该数据流路径的起始路径点或终止路径点为目标子系统。
[0171]
在上述各实施例的基础上,还可以包括,时间偏移处理模块,用于:
[0172]
在确定出与设定时间片下执行的每个子数据流分别对应的数据流路径之后,在全部子数据流中,获取与目标时间片对应的目标子数据流;
[0173]
获取与目标子数据流匹配的目标数据流路径,并计算目标数据流路径中包括的路径点数量;
[0174]
以目标时间片为起点,获取与路径点数量匹配的连续时间片集合;
[0175]
将目标数据流路径中包括的各路径点顺序映射至连续时间片集合中的各时间片中;
[0176]
返回执行在全部子数据流中,获取与目标时间片对应的目标子数据流的操作,直至完成对全部子数据流的数据流路径的时间偏移处理。
[0177]
在上述各实施例的基础上,还可以包括,执行顺序检查模块,用于:
[0178]
在完成对全部子数据流的时间偏移处理后,获取与全部子数据流匹配的时间片起终点范围,并在时间片起终点范围内依次获取当前处理时间片;
[0179]
在每个子数据流的数据流路径中,分别识别与当前时间片匹配的映射路径点;
[0180]
根据至少一个执行顺序检查规则,对各映射路径点进行数据流执行顺序的检查,并在检测到执行顺序异常时,对各子数据流的数据流路径进行重排布,以确保任务执行顺序不被打乱;
[0181]
返回执行在时间片起终点范围内依次获取当前处理时间片的操作,直至完成对时间片起终点范围内全部时间片的数据流执行顺序的检查。
[0182]
在上述各实施例的基础上,所述执行顺序检查规则可以包括:
[0183]
缓存空间的限制规则,以及缓存使用策略限制规则,其中,缓存使用策略限制规则包括:替换策略或预取策略。
[0184]
在上述各实施例的基础上,还可以包括,多数据流处理模块,用于:
[0185]
获取与多个数据流中的各子数据流分别对应的数据流路径;
[0186]
根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布。
[0187]
在上述各实施例的基础上,还可以包括,排布结果修正模块,用于:
[0188]
在根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布之后,如果多个数据流中存在数据接力节点,则根据数据接力节点所在位置,对排布结果进行修正;其中,数据接力节点包括数据接力空间节点和/或数据接力时间节点;
[0189]
和/或
[0190]
如果多个数据流中存在数据同步关系,则根据数据同步关系所在位置,对排布结果进行修正。
[0191]
本发明实施例所提供的数据流的时空映射装置可执行本发明任意实施例所提供的数据流的时空映射方法,具备执行方法相应的功能模块和有益效果。
[0192]
实施例七
[0193]
图16为本发明实施例七提供的一种计算机设备的结构示意图,如图16所示,该计算机设备包括处理器1610、存储器1620、输入装置1630和输出装置1640;计算机设备中处理器1610的数量可以是一个或多个,图16中以一个处理器1610为例;计算机设备中的处理器1610、存储器1620、输入装置1630和输出装置1640可以通过总线或其他方式连接,图16中以通过总线连接为例。
[0194]
存储器1620作为一种计算机可读存储介质,可用于存储软件程序、计算机可执行程序以及模块,如本发明实施例中的数据流的时空映射方法对应的程序指令/模块(例如,目标数据流获取模块1510、时域映射模块1520以及空域映射模块1530)。处理器1610通过运
行存储在存储器1620中的软件程序、指令以及模块,从而执行设备/终端/服务器的各种功能应用以及数据处理,即实现上述的数据流的时空映射方法。
[0195]
也即:获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;
[0196]
根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;
[0197]
根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
[0198]
存储器1620可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序;存储数据区可存储根据终端的使用所创建的数据等。此外,存储器1620可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他非易失性固态存储器件。在一些实例中,存储器1620可进一步包括相对于处理器1610远程设置的存储器,这些远程存储器可以通过网络连接至设备/终端/服务器。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
[0199]
输入装置1630可用于接收输入的数字或字符信息,以及产生与计算机设备的用户设置以及功能控制有关的键信号输入。输出装置1640可包括显示屏等显示设备。
[0200]
实施例八
[0201]
本发明实施例八还提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行一种数据流的时空映射方法,该方法包括:
[0202]
获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;
[0203]
根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;
[0204]
根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。
[0205]
当然,本发明实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的方法操作,还可以执行本发明任意实施例所提供的数据流的时空映射方法中的相关操作。
[0206]
通过以上关于实施方式的描述,所属领域的技术人员可以清楚地了解到,本发明可借助软件及必需的通用硬件来实现,当然也可以通过硬件实现,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品可以存储在计算机可读存储介质中,如计算机的软盘、只读存储器(read-only memory, rom)、随机存取存储器(random access memory, ram)、闪存(flash)、硬盘或光盘等,包括若干指令用以使得一台计算机设
备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述的方法。
[0207]
值得注意的是,上述搜索装置的实施例中,所包括的各个单元和模块只是按照功能逻辑进行划分的,但并不局限于上述的划分,只要能够实现相应的功能即可;另外,各功能单元的具体名称也只是为了便于相互区分,并不用于限制本发明的保护范围。
[0208]
注意,上述仅为本发明的较佳实施例及所运用技术原理。本领域技术人员会理解,本发明不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本发明的保护范围。因此,虽然通过以上实施例对本发明进行了较为详细的说明,但是本发明不仅仅限于以上实施例,在不脱离本发明构思的情况下,还可以包括更多其他等效实施例,而本发明的范围由所附的权利要求范围决定。

技术特征:
1.一种数据流的时空映射方法,其特征在于,包括:获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。2.根据权利要求1所述的方法,其特征在于,根据目标数据流中定义的与该负载任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流,包括:根据目标数据流中包括的目标子任务中各数据维度的执行顺序,并行维度和和目标子任务中各数据维度的切片大小,将目标数据流拆分为多个子数据流,并确定每个子数据流的执行顺序;按照各子数据流的执行顺序,并将各子数据流在多个连续时间片上进行顺序排布。3.根据权利要求1所述的方法,其特征在于,根据负载任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再映射空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,包括:获取与目标子任务具有架构映射关系的目标子系统,并根据目标子系统和目标架构中定义的各子系统的连接关系,确定出与设定时间片下执行的每个子数据流分别对应的数据流路径;其中,数据流路径由多个相邻层级的子系统串联构成,且该数据流路径的起始路径点或终止路径点为目标子系统。4.根据权利要求3所述的方法,其特征在于,在确定出与设定时间片下执行的每个子数据流分别对应的数据流路径之后,还包括:在全部子数据流中,获取与目标时间片对应的目标子数据流;获取与目标子数据流匹配的目标数据流路径,并计算目标数据流路径中包括的路径点数量;以目标时间片为起点,获取与路径点数量匹配的连续时间片集合;将目标数据流路径中包括的各路径点顺序映射至连续时间片集合中的各时间片中;返回执行在全部子数据流中,获取与目标时间片对应的目标子数据流的操作,直至完成对全部子数据流的数据流路径的时间偏移处理。5.根据权利要求4所述的方法,其特征在于,在完成对全部子数据流的时间偏移处理后,还包括:获取与全部子数据流匹配的时间片起终点范围,并在时间片起终点范围内依次获取当前处理时间片;在每个子数据流的数据流路径中,分别识别与当前时间片匹配的映射路径点;根据至少一个执行顺序检查规则,对各映射路径点进行数据流执行顺序的检查,并在
检测到执行顺序异常时,对各子数据流的数据流路径进行重排布,以确保任务执行顺序不被打乱;返回执行在时间片起终点范围内依次获取当前处理时间片的操作,直至完成对时间片起终点范围内全部时间片的数据流执行顺序的检查。6.根据权利要求5所述的方法,其特征在于,所述执行顺序检查规则包括:缓存空间的限制规则,以及缓存使用策略限制规则,其中,缓存使用策略限制规则包括:替换策略或预取策略。7.根据权利要求3-6任一项所述的方法,其特征在于,所述方法还包括:获取与多个数据流中的各子数据流分别对应的数据流路径;根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布。8.根据权利要求7所述的方法,其特征在于,在根据不同数据流之间的依赖关系,将与各子数据流分别对应的数据流路径在统一时间线上进行排布之后,还包括:如果多个数据流中存在数据接力节点,则根据数据接力节点所在位置,对排布结果进行修正;其中,数据接力节点包括数据接力空间节点和/或数据接力时间节点;和/或如果多个数据流中存在数据同步关系,则根据数据同步关系所在位置,对排布结果进行修正。9.一种数据流的时空映射装置,其特征在于,包括:目标数据流获取模块,用于获取待时空映射的目标数据流,其中,目标数据流由负载任务拆分出的一个目标子任务生成,负载任务为待加载至目标架构执行基准测试的任务;时域映射模块,用于根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;空域映射模块,用于根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。10. 一种电子设备,其特征在于,所述电子设备包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的计算机程序,所述计算机程序被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-8中任一项所述的数据流的时空映射方法。11.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机指令,所述计算机指令用于使处理器执行时实现权利要求1-8中任一项所述的数据流的时空映射方法。

技术总结
本发明公开了一种数据流的时空映射方法、装置、设备及介质。该方法包括:获取待时空映射的目标数据流;根据目标数据流中定义的与该目标子任务匹配的各数据维度的执行顺序,并行维度和各数据维度的切片大小,对目标数据流进行时域映射,得到多个具有时域执行顺序的子数据流;根据目标子任务在目标架构中所映射的目标子系统和目标架构中定义的各子系统的连接关系,对各子数据流再进行空域映射,将在设定时间片下执行的每个子数据流分别映射至目标架构各层级的子系统中,作为该基准测试中的一项建模参考信息。本发明实施例的技术方案可以准确、高效的将数据流任务在时间和空间维度进行双重映射,为后续进行基准测试建模提供数据准备。备。备。


技术研发人员:汪洪博 潘佳诚
受保护的技术使用者:上海燧原科技有限公司
技术研发日:2023.06.27
技术公布日:2023/8/1
版权声明

本文仅代表作者观点,不代表航家之家立场。
本文系作者授权航家号发表,未经原创作者书面授权,任何单位或个人不得引用、复制、转载、摘编、链接或以其他任何方式复制发表。任何单位或个人在获得书面授权使用航空之家内容时,须注明作者及来源 “航空之家”。如非法使用航空之家的部分或全部内容的,航空之家将依法追究其法律责任。(航空之家官方QQ:2926969996)

航空之家 https://www.aerohome.com.cn/

飞机超市 https://mall.aerohome.com.cn/

航空资讯 https://news.aerohome.com.cn/

分享:

扫一扫在手机阅读、分享本文

相关推荐