一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

图像处理方法、装置、电子设备和存储介质与流程

2022-12-21 20:02:20 来源:中国专利 TAG:


1.本公开涉及计算机视觉技术,尤其是一种图像处理方法、装置、电子设备和存储介质。


背景技术:

2.近来,transformer神经网络模型逐渐被用于跨空间(cross-space或cross-view)的特征关联学习任务,该任务主要通过交叉注意力(cross-space attention)实现,交叉注意力是指不同数据模态(比如图像坐标系下的图像特征与鸟瞰视角(bird'seye view,简称:bev)坐标系下的bev特征属于两种数据模态,图像特征与文本特征属于两种数据模态,等等)之间、相同数据模态的不同数据之间的注意力操作。实现交叉注意力的核心为多头注意力机制(mha,multi-head attention),由于图像特征是二维特征图,在进行注意力操作时,将特征图每个位置的像素作为token(令牌),导致输入的token数量会非常大,比如一个特征图的token数量就可能达到万数以上,在实际应用中通常会有多个特征图,导致交叉注意力操作的计算量过大,使得图像处理效率较低。


技术实现要素:

3.为了解决上述图像处理效率较低等技术问题,提出了本公开。本公开的实施例提供了一种图像处理方法、装置、电子设备和存储介质。
4.根据本公开实施例的一个方面,提供了一种图像处理方法,包括:确定待处理图像对应的第一张量;基于所述第一张量,确定所述第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量;基于第二张量,确定查询张量,所述第二张量为待与所述第一张量进行交叉注意力操作的张量;基于所述第一键张量和所述查询张量进行注意力操作,获得第一注意力权重;基于所述第二键张量和所述查询张量进行注意力操作,获得第二注意力权重;基于所述第一注意力权重、所述第一值张量、所述第二注意力权重及所述第二值张量,确定目标输出张量;基于所述目标输出张量,确定所述待处理图像对应的图像处理结果。
5.根据本公开实施例的另一个方面,提供了一种图像处理装置,包括:第一确定模块,用于确定待处理图像对应的第一张量;第一处理模块,用于基于所述第一张量,确定所述第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量;第二处理模块,用于基于第二张量,确定查询张量,所述第二张量为待与所述第一张量进行交叉注意力操作的张量;第三处理模块,用于基于所述第一键张量和所述查询张量进行注意力操作,获得第一注意力权重;第四处理模块,用于基于所述第二键张量和所述查询张量进行注意力操作,获得第二注意力权重;第五处理模块,用于基于所述第一注意力权重、所述第一值张量、所述第二注意力权重及所述第二值张量,确定目标输出张量;第六处理模块,用于基于所述目标输出张量,确定所述待处理图像对应的图像处理结果。
6.根据本公开实施例的再一方面,提供一种计算机可读存储介质,所述存储介质存储有计算机程序,所述计算机程序用于执行本公开上述任一实施例所述的图像处理方法。
7.根据本公开实施例的又一方面,提供一种电子设备,所述电子设备包括:处理器;用于存储所述处理器可执行指令的存储器;所述处理器,用于从所述存储器中读取所述可执行指令,并执行所述指令以实现本公开上述任一实施例所述的图像处理方法。
8.基于本公开上述实施例提供的图像处理方法、装置、电子设备和存储介质,通过基于待处理图像对应的第一张量,确定第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量及列向聚合的第二值张量,实现了对键张量和值张量的降维,用于交叉注意力操作,可以有效降低计算复杂度,从而提高图像处理效率。
9.下面通过附图和实施例,对本公开的技术方案做进一步的详细描述。
附图说明
10.通过结合附图对本公开实施例进行更详细的描述,本公开的上述以及其他目的、特征和优势将变得更加明显。附图用来提供对本公开实施例的进一步理解,并且构成说明书的一部分,与本公开实施例一起用于解释本公开,并不构成对本公开的限制。在附图中,相同的参考标号通常代表相同部件或步骤。
11.图1是本公开提供的图像处理方法的一个示例性的应用场景;
12.图2是本公开一示例性实施例提供的图像处理方法的流程示意图;
13.图3是本公开一示例性实施例提供的第一键张量、第一值张量、第二键张量和第二值张量的示意图;
14.图4是本公开一示例性实施例提供的步骤202的流程示意图;
15.图5是本公开一示例性实施例提供的第一张量的聚合原理示意图;
16.图6是本公开另一示例性实施例提供的步骤202的流程示意图;
17.图7是本公开一示例性实施例提供的第一张量的映射原理示意图;
18.图8是本公开另一示例性实施例提供的图像处理方法的流程示意图;
19.图9是本公开一示例性实施例提供的单个token的权重值的示意图;
20.图10是本公开一示例性实施例提供的第一输出张量和第二输出张量的示意图;
21.图11是本公开一示例性实施例提供的detr网络的结构示意图;
22.图12是本公开一示例性实施例提供的图像处理装置的结构示意图;
23.图13是本公开一示例性实施例提供的第一处理模块502的结构示意图;
24.图14是本公开另一示例性实施例提供的第一处理模块502的结构示意图;
25.图15是本公开另一示例性实施例提供的图像处理装置的结构示意图;
26.图16是本公开电子设备一个应用实施例的结构示意图。
具体实施方式
27.下面,将参考附图详细地描述根据本公开的示例实施例。显然,所描述的实施例仅仅是本公开的一部分实施例,而不是本公开的全部实施例,应理解,本公开不受这里描述的示例实施例的限制。
28.应注意到:除非另外具体说明,否则在这些实施例中阐述的部件和步骤的相对布
置、数字表达式和数值不限制本公开的范围。
29.本领域技术人员可以理解,本公开实施例中的“第一”、“第二”等术语仅用于区别不同步骤、设备或模块等,既不代表任何特定技术含义,也不表示它们之间的必然逻辑顺序。
30.还应理解,在本公开实施例中,“多个”可以指两个或两个以上,“至少一个”可以指一个、两个或两个以上。
31.还应理解,对于本公开实施例中提及的任一部件、数据或结构,在没有明确限定或者在前后文给出相反启示的情况下,一般可以理解为一个或多个。
32.另外,本公开中术语“和/或”,仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,a和/或b,可以表示:单独存在a,同时存在a和b,单独存在b这三种情况。另外,本公开中字符“/”,一般表示前后关联对象是一种“或”的关系。
33.还应理解,本公开对各个实施例的描述着重强调各个实施例之间的不同之处,其相同或相似之处可以相互参考,为了简洁,不再一一赘述。
34.同时,应当明白,为了便于描述,附图中所示出的各个部分的尺寸并不是按照实际的比例关系绘制的。
35.以下对至少一个示例性实施例的描述实际上仅仅是说明性的,决不作为对本公开及其应用或使用的任何限制。
36.对于相关领域普通技术人员已知的技术、方法和设备可能不作详细讨论,但在适当情况下,所述技术、方法和设备应当被视为说明书的一部分。
37.应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步讨论。
38.本公开实施例可以应用于终端设备、计算机系统、服务器等电子设备,其可与众多其它通用或专用计算系统环境或配置一起操作。适于与终端设备、计算机系统、服务器等电子设备一起使用的众所周知的终端设备、计算系统、环境和/或配置的例子包括但不限于:个人计算机系统、服务器计算机系统、瘦客户机、厚客户机、手持或膝上设备、基于微处理器的系统、机顶盒、可编程消费电子产品、网络个人电脑、小型计算机系统、大型计算机系统和包括上述任何系统的分布式云计算技术环境,等等。
39.终端设备、计算机系统、服务器等电子设备可以在由计算机系统执行的计算机系统可执行指令(诸如程序模块)的一般语境下描述。通常,程序模块可以包括例程、程序、目标程序、组件、逻辑、数据结构等等,它们执行特定的任务或者实现特定的抽象数据类型。计算机系统/服务器可以在分布式云计算环境中实施,分布式云计算环境中,任务是由通过通信网络链接的远程处理设备执行的。在分布式云计算环境中,程序模块可以位于包括存储设备的本地或远程计算系统存储介质上。
40.本公开概述
41.在实现本公开的过程中,发明人发现,近来,transformer神经网络模型逐渐被用于跨空间(cross-space或cross-view)的特征关联学习任务,该任务主要通过交叉注意力(cross-space attention)实现,交叉注意力是指不同数据模态(比如图像坐标系下的图像特征与鸟瞰视角(bird's eye view,简称:bev)坐标系下的bev特征属于两种数据模态,再比如图像特征与文本特征属于两种数据模态,等等)之间、相同数据模态的不同数据之间的
注意力操作。实现交叉注意力的核心为多头注意力机制(mha,multi-head attention),由于图像特征是二维特征图,在进行注意力操作时,将特征图每个位置的像素作为token(令牌),导致输入的token数量会非常大,比如一个特征图的token数量就可能达到万数以上,在实际应用中通常会有多个特征图,导致交叉注意力操作的计算量过大,使得图像处理效率较低。
42.示例性概述
43.图1是本公开提供的图像处理方法的一个示例性的应用场景。
44.在自动驾驶领域,涉及需要进行bev(bird’s eye view,鸟瞰图视角)语义分割的场景,通常需要将待处理图像的图像特征与bev嵌入特征(bev embedding)进行交叉注意力,参见图1,待处理图像(即输入图像)经特征提取网络处理,获得其对应的第一图像特征,第一图像特征加上空间位置编码后作为交叉注意力(cross-space attention)的第一张量,bev embedding经初始化后作为交叉注意力的第二张量,第一张量与第二张量进行交叉注意力操作,即第一张量用于确定交叉注意力操作的键张量(key)和值张量(value),第二张量用于确定交叉注意力操作的查询张量(query),基于查询张量和键张量获得注意力权重,注意力权重作用于值张量,获得注意力操作的目标输出张量,注意力权重作用于值张量是指基于注意力权重将值张量的每个通道的像素值进行加权求和,获得目标输出张量。具体来说,对于查询张量的每个token(每个像素位置的c通道的像素值形成的c维向量),将该token与键张量的转置相乘可以获得该token对应的注意力权重,该token对应的注意力权重作为值张量中每个通道的各位置像素值的权重,将值张量中每个通道的像素值进行加权求和,获得该token对应的输出结果,所有token的输出结果形成目标输出张量。目标输出张量经bev decoder(bev解码器)及语义分割预测获得待处理图像对应的bev语义分割结果。利用本公开的图像处理方法,在第一张量与第二张量进行交叉注意力操作时,可以基于第一张量,确定第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量,基于第二张量,确定查询张量,基于第一键张量和查询张量进行注意力操作,获得第一注意力权重,基于第二键张量和查询张量进行注意力操作,获得第二注意力权重,基于第一注意力权重、第一值张量、第二注意力权重及第二值张量,确定目标输出张量,由于确定的是轴向(行向或列向)聚合的键张量和值张量,实现了键张量和值张量的降维,用于交叉注意力操作,可以大大降低计算复杂度,有效提高图像处理效率。
45.本公开的图像处理方法不限于上述自动驾驶的相关场景,在实际应用中可以根据实际需求应用于任意需要进行交叉注意力操作的场景,比如在需要基于detr(detection transformer,检测变换器)及其系列(比如deformable detr(deformable detection transformer,可变形检测变换器))的网络架构完成一定任务场景,detr是transformer的视觉版本,可以用于目标检测,也可以用于全景分割,detr的解码器中包括编码-解码注意力层,该编码-解码注意力层为交叉注意力层,其键张量和值张量基于编码器提取的特征图确定,其查询张量基于object query(对象查询特征)确定,则可以利用本公开的图像处理方法实现交叉注意力以降低计算复杂度,具体可以根据实际需求设置。
46.示例性方法
47.图2是本公开一示例性实施例提供的图像处理方法的流程示意图。本实施例可应
用在电子设备上,具体比如服务器或终端上,如图2所示,包括如下步骤:
48.步骤201,确定待处理图像对应的第一张量。
49.其中,待处理图像可以为任意需要进行处理的图像,比如需要进行目标检测的图像、需要进行语义分割的图像,等等,具体不作限定。待处理图像可以包括一个或多个图像。待处理图像对应的第一张量是对待处理图像进行一定的处理(比如特征提取)获得的用于进行交叉注意力操作的张量,比如前述图1中提取的第一图像特征与空间位置编码张量相加的结果作为第一张量,具体第一张量的确定可以根据实际需求设置,在此不再赘述。
50.步骤202,基于第一张量,确定第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量。
51.其中,行向聚合的第一键张量是在行向上进行降维后的键张量,比如第一张量大小为c
×
h1
×
w1,c、h1、w1分别表示通道数量、高度和宽度。获得的第一键张量大小为c
×
h1
×
1,将每行的w1维聚合成1维,具体降维后的第一键张量的行向维度可以根据实际需求设置,比如降维后的第一键张量的宽度w可以为w1/2、w1/4、2、1,等等,具体不作限定。列向聚合的第二键张量是在列向上进行降维后的键张量,比如获得的第二键张量大小为c
×1×
w1,将每列的h1维聚合成1维或小于h1的多维。同理,行向聚合的第一值张量是在行向上进行降维的值张量,列向聚合的第二值张量是在列向上进行降维的值张量。需要说明的是,第一键张量、第二键张量、第一值张量和第二值张量的大小需要相同。由于键张量和值张量均进行了降维,从而可以降低注意力操作的计算量。
52.示例性的,图3是本公开一示例性实施例提供的第一键张量、第一值张量、第二键张量和第二值张量的示意图。在本示例中,第一键张量和第一值张量是在行向上被降维成w=1的张量,第二键张量和第二值张量是在列向上被降维成h=1的张量。这种情况下,可以实现将原本的二维注意力操作转换成两个一维的注意力操作,可以大大降低注意力操作的计算复杂度,提高图像处理效率。
53.可选地,对于降维后的第一键张量、第二键张量、第一值张量和第二值张量,可以是先对第一张量分别进行行向和列向聚合,再基于行向聚合结果进行映射,获得行向聚合的第一键张量和第一值张量,基于列向聚合结果进行映射获得列向聚合的第二键张量和第二值张量;也可以是先对第一张量进行映射获得键张量和值张量,再分别对键张量和值张量进行行向和列向聚合,获得第一键张量、第一值张量、第二键张量和第二值张量,本实施例不作限定。第一张量可以通过预设映射规则映射为键张量和值张量,具体不再赘述。
54.步骤203,基于第二张量,确定查询张量,第二张量为待与第一张量进行交叉注意力操作的张量。
55.其中,第二张量可以根据交叉注意力的实际应用需求确定,比如上述的bev embedding,具体不作限定。可以通过一定的映射规则将第二张量映射为查询张量,具体不再赘述。
56.步骤202和步骤203不分先后顺序。
57.步骤204,基于第一键张量和查询张量进行注意力操作,获得第一注意力权重。
58.其中,第一键张量与查询张量的注意力操作是指将查询张量中每个位置的c维向量作为token(令牌),与第一键张量中每个位置的c维向量的转置相乘(内积,即c个值对应相乘再求和),获得查询张量的每个位置对应的权重值,查询张量各位置分别对应的权重值
形成第一注意力权重。
59.步骤205,基于第二键张量和查询张量进行注意力操作,获得第二注意力权重。
60.该步骤的注意力操作原理与步骤204相同或相似,在此不再赘述。
61.步骤204和步骤205不分先后顺序。
62.步骤206,基于第一注意力权重、第一值张量、第二注意力权重及第二值张量,确定目标输出张量。
63.其中,第一注意力权重作用于第一值张量,获得第一输出张量,第二注意力权重作用于第二值张量,获得第二输出张量,结合第一输出张量和第二输出张量获得目标输出张量。第一注意力权重包括多个token分别对应的注意力权重,第一注意力权重作用于第一值张量是指基于第一注意力权重中每个token对应的注意力权重对第一值张量的每个通道的像素值进行加权求和,获得第一输出张量。
64.步骤207,基于目标输出张量,确定待处理图像对应的图像处理结果。
65.其中,在获得交叉注意力的目标输出张量后,可以基于目标输出张量进行后续的处理,比如解码、输出投影等,获得待处理图像对应的图像处理结果。具体后续处理可以根据实际需求设置,本实施例不做限定。
66.本实施例提供的图像处理方法,通过基于待处理图像对应的第一张量,确定第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量及列向聚合的第二值张量,实现了对键张量和值张量的降维,用于交叉注意力操作,可以有效降低计算复杂度,从而提高图像处理效率。
67.图4是本公开一示例性实施例提供的步骤202的流程示意图。
68.在一个可选示例中,步骤202具体可以包括以下步骤:
69.步骤2021a,基于第一张量,确定行向聚合的第一聚合张量、及列向聚合的第二聚合张量。
70.其中,行向聚合和列向聚合可以通过池化操作实现,通过对第一张量进行行向聚合获得第一聚合张量,对第一张量进行列向聚合获得第二聚合张量。行向聚合是将第一张量的宽度w1进行降维,列向聚合是将第一张量的高度h1进行降维,具体降维后的维度可以根据实际需求设置。比如将第一张量的宽度聚合成1维,获得第一聚合张量,将第一张量的高度聚合成1维获得第二聚合张量。
71.步骤2022a,基于第一聚合张量及第一映射规则,确定第一键张量。
72.其中,第一映射规则可以根据实际需求设置,比如可以为第一键张量对应的第一映射矩阵wk。
73.步骤2023a,基于第二聚合张量及第二映射规则,确定第二键张量。
74.其中,第二映射规则可以根据实际需求设置,比如可以为第二键张量对应的第二映射矩阵。
75.在实际应用中,第二映射矩阵与第一映射矩阵可以为同一映射矩阵wk。
76.步骤2024a,基于第一聚合张量及第三映射规则,确定第一值张量。
77.其中,第三映射规则可以为第一值张量对应的第三映射矩阵。
78.步骤2025a,基于第二聚合张量及第四映射规则,确定第二值张量。
79.其中,第四映射规则可以为第二值张量对应的第四映射矩阵。在实际应用中,第四
映射矩阵与第三映射矩阵可以为同一映射矩阵wv。
80.示例性的,图5是本公开一示例性实施例提供的第一张量的聚合原理示意图。第一张量经行向聚合获得第一聚合张量,第一聚合张量通过wk映射得到第一键张量,第一聚合张量通过wv映射得到第一值张量,第一张量经列向聚合获得第二聚合张量,第二聚合张量通过wk映射得到第二键张量,第二聚合张量通过wv映射得到第二值张量。
81.本公开通过将第一张量在行向和列向进行聚合,获得行向聚合的第一聚合张量及列向聚合的第二聚合张量,进而基于聚合后的第一聚合张量映射为第一键张量和第一值张量,基于第二聚合张量映射为第二键张量和第二值张量,实现键张量和值张量的降维,从而降低注意力操作的计算复杂度。
82.在一个可选示例中,步骤2021a的基于第一张量,确定行向聚合的第一聚合张量、及列向聚合的第二聚合张量,包括:对第一张量在行向上进行第一预设池化操作,确定第一聚合张量;对第一张量在列向上进行第二预设池化操作,确定第二聚合张量。
83.其中,第一预设池化(pooling)操作和第二预设池化操作的具体池化方式可以根据实际需求设置,比如通过神经网络中的池化层(pooling layer)实现对第一张量的聚合,其中池化操作可以是平均池化(average pooling)、最大池化(average pooling),等等。池化操作的作用是将输入特征降维,具体原理不再赘述。
84.本公开通过池化操作实现第一张量的聚合,进而实现键张量和值张量的降维,降低注意力操作的计算量。
85.图6是本公开另一示例性实施例提供的步骤202的流程示意图。
86.在一个可选示例中,步骤202的基于第一张量,确定第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量,包括:
87.步骤2021b,基于第一张量,确定第三键张量及第三值张量。
88.其中,可以通过键张量对应的映射矩阵将第一张量映射为第三键张量,同理,基于值张量对应的映射矩阵将第一张量映射为第三值张量,第三键张量和第三值张量为与第一张量大小相同的张量。
89.步骤2022b,对第三键张量在行向进行聚合操作,获得第一键张量。
90.其中,行向聚合操作原理与前述第一张量的聚合类似,在此不再赘述。
91.步骤2023b,对第三键张量在列向进行聚合操作,获得第二键张量。
92.其中,列向聚合操作原理参见前述内容,在此不再赘述。
93.步骤2024b,对第三值张量在行向进行聚合操作,获得第一值张量。
94.其中,行向聚合操作原理参见前述内容,在此不再赘述。
95.步骤2025b,对第三值张量在列向进行聚合操作,获得第二值张量。
96.其中,列向聚合操作原理参见前述内容,在此不再赘述。
97.示例性的,图7是本公开一示例性实施例提供的第一张量的映射原理示意图。第一张量经映射矩阵wk映射得到第三键张量,第三键张量通过行向聚合获得第一键张量,第三键张量通过列向聚合获得第二键张量;第一张量经映射矩阵wv映射得到第三值张量,第三值张量经行向聚合获得第一值张量,第三值张量经列向聚合获得第二值张量。
98.本公开通过第一张量先映射为相同大小的第三键张量和第三值张量,再将第三键
张量和第三值张量进行行向聚合和列向聚合,获得第一键张量、第一值张量、第二键张量和第二值张量,实现键张量和值张量的降维。上述的相同大小是指第三键张量和第三值张量的宽度、高度和通道数量均相同,比如均为c
×
h1
×
w1。
99.图8是本公开另一示例性实施例提供的图像处理方法的流程示意图。
100.在一个可选示例中,步骤204的基于第一键张量和查询张量进行注意力操作,获得第一注意力权重,包括:
101.步骤2041,针对查询张量中的任一第一位置的c维向量,将该c维向量与第一键张量中每个第二位置的c维向量的转置相乘,获得该第一位置对应的权重值,c表示查询张量和第一键张量的通道数量。
102.示例性的,查询张量表示为q=q
[1:h2,1:w2,1:c]
,第一键张量表示为k=k
[1:h1,1:w,1:c]
,w小于第一张量的宽度w1,对于查询张量中的每个token,表示为q
[i,j,1:c]
=[q1,q2,

,qc],i=1,2,

,h2,j=1,2,

,w2,第一键张量中每个第二位置的c维向量表示为k
[l,k,1:c]
=[k1,k2,

,kc],l=1,2,

,h1,k=1,2,

,w,则对于查询张量中的第i行、第j列位置对应的权重值表示如下:
[0103][0104]
其中,z
[1:h1,1:w]
表示h1
×
w的张量,也即包括h1
×
w个权重值,对于第一键张量中的每个第二位置,该第二位置的权重值表示为q1k1 q2k2

qckc。
[0105]
示例性的,图9是本公开一示例性实施例提供的单个token的权重值的示意图。对于每个token,与第一键张量(c
×
h1
×
w)的注意力操作获得的该token对应的权重值的大小为h1
×
w,以w=1为例,查询张量包括h2
×
w2个token,因此会获得h2
×
w2个大小为h1
×
w的权重值(称为第一权重值)。
[0106]
步骤2042,基于各第一位置分别对应的权重值,确定第一注意力权重。
[0107]
将上述获得的h2
×
w2个大小为h1
×
w的权重值作为第一注意力权重。
[0108]
本公开基于行向聚合的第一键张量与查询张量进行注意力操作,获得第一注意力权重,相对于现有键张量的全量注意力操作,大大减少了计算量。
[0109]
在一个可选示例中,步骤205的基于第二键张量和查询张量进行注意力操作,获得第二注意力权重,包括:
[0110]
步骤2051,针对查询张量中的任一第一位置的c维向量,将该c维向量与第二键张量中每个第三位置的c维向量的转置相乘,获得该第一位置对应的权重值,c表示查询张量和第二键张量的通道数量。
[0111]
步骤2052,基于各第一位置分别对应的权重值,确定第二注意力权重。
[0112]
步骤2051-2052的具体操作原理参见上述步骤2041-2042,在此不再赘述。
[0113]
在一个可选示例中,步骤206的基于第一注意力权重、第一值张量、第二注意力权重及第二值张量,确定目标输出张量,包括:
[0114]
步骤2061,基于第一注意力权重及第一值张量,确定第一输出张量。
[0115]
其中,第一注意力权重作用于第一值张量,获得第一输出张量。具体来说,基于第一注意力权重将第一值张量中每个通道的像素值进行加权求和,获得第一输出张量。
[0116]
步骤2062,基于第二注意力权重及第二值张量,确定第二输出张量。
[0117]
其中,该步骤的具体操作与步骤2061类似,在此不再赘述,获得的第二输出张量同第一输出张量大小相同。
[0118]
示例性的,图10是本公开一示例性实施例提供的第一输出张量和第二输出张量的示意图。在本示例中以单个token为例,每个token对应的第一权重值作用于第一值张量,获得c
×1×
1的第一输出结果,具体来说,对于第一值张量中的每个通道,将h1
×
w的第一权重值中每个位置的值作为第一值张量中对应位置的像素值的权重,基于该第一权重值,将第一值张量中该通道的h1
×
w个像素值进行加权求和,获得该通道的1
×
1的输出结果,c个通道的1
×
1的输出结果形成c
×1×
1的第一输出结果。查询张量对应的h2
×
w2个token则可以获得h2
×
w2个c
×1×
1的第一输出结果,该h2
×
w2个c
×1×
1的第一输出结果形成c
×
h2
×
w2的第一输出张量。同理,每个token对应的第二权重值作用于第二值张量,获得c
×1×
1的第二输出结果,查询张量对应的h2
×
w2个token则可以获得h2
×
w2个c
×1×
1的第二输出结果,该h2
×
w2个c
×1×
1的第二输出结果形成c
×
h2
×
w2的第二输出张量。
[0119]
步骤2063,基于第一输出张量和第二输出张量,确定目标输出张量。
[0120]
其中,第一输出张量与第二输出张量融合即可获得目标输出张量,具体融合方式可以根据实际需求设置。
[0121]
本公开通过聚合的键张量(第一键张量和第二键张量)获得的注意力权重,作用于聚合的值张量(第一值张量和第二值张量),进一步降低计算量。
[0122]
在一个可选示例中,步骤2063基于第一输出张量和第二输出张量,确定目标输出张量,包括:将第一输出张量与第二输出张量相加,获得目标输出张量。
[0123]
其中,第一输出张量与第二输出张量相加是指两张量对应元素相加。
[0124]
在一个可选示例中,步骤203的基于第二张量,确定查询张量,包括:
[0125]
步骤2031,基于第二张量及第五映射规则,确定查询张量。
[0126]
其中,第五映射规则可以根据实际需求设置,比如为查询张量对应的映射矩阵wq,具体不再赘述。
[0127]
在一个可选示例中,步骤207的基于目标输出张量,确定待处理图像对应的图像处理结果,包括:
[0128]
步骤2071,将目标输出张量与第二张量相加,获得第三张量。
[0129]
其中,目标输出张量与第二张量可以通过残差连接实现相加,获得第三张量。
[0130]
步骤2072,对第三张量进行归一化,获得第四张量。
[0131]
其中,第三张量的归一化方式可以根据实际需求设置,比如层归一化(layer normalization,简称:ln)、批量归一化(batch normalization,简称:bn),等等,具体不作限定。
[0132]
步骤2073,基于第四张量,确定待处理图像对应的图像处理结果。
[0133]
其中,第四张量还可以经解码器、输出投影等,确定待处理图像对应的图像处理结果,具体可以根据实际需求设置。
[0134]
示例性的,图11是本公开一示例性实施例提供的detr网络的结构示意图,其中,image features表示图像特征,multi-head self-attention表示多头自注意力网络,add&norm表示相加并归一化,ffn(feed forward networks)表示前馈网络,multi-head attention表示多头注意力网络,object queries表示对象查询特征,class表示分类,
bounding box表示预测框,encoder表示编码器,decoder表示解码器,n
×
表示有n个编码器,m
×
表示有m个解码器。可见在detr网络中,在每个解码器(decoder)中均包括交叉注意力网络(multi-head attention),其键张量和值张量是基于从编码器获得的图像特征结合空间位置编码确定,其查询张量则基于可初始化的object queries(对象查询特征)及其自注意力结果的归一化结果确定,对于该detr网络即可利用本公开的图像处理方法,在交叉注意力网络部分,对键张量和值张量进行轴向(行向和列向)聚合,再与查询张量进行注意力操作,以有效降低注意力操作的计算复杂度,提高图像处理效率。交叉注意力获得的目标输出张量还需要与其前面的归一化结果进行相加并归一化,获得第四张量,第四张量经后续的前馈网络(ffn)、add&norm、及两个预测头的ffn获得分类和预测框,作为待处理图像对应的图像处理结果,detr的具体原理在此不再赘述。同理,在其他任意具有交叉注意力的神经网络的应用中,均可以采用本公开的交叉注意力方式,以降低计算复杂度。
[0135]
在一个可选示例中,步骤201的确定待处理图像对应的第一张量,包括:
[0136]
步骤2011,对待处理图像进行特征提取,获得待处理图像对应的第一图像特征。
[0137]
其中,特征提取方式可以根据实际需求设置,比如基于特征提取网络进行特征提取,特征提取网络可以为任意可实施的网络,比如卷积神经网络、编码器网络等等。
[0138]
步骤2012,基于第一图像特征及第一图像特征对应的空间位置编码张量,确定第一张量。
[0139]
其中,第一图像特征可以与空间位置编码张量相加获得第一张量。
[0140]
在一个可选示例中,可以基于第一张量获得行向聚合为1维(宽度w=1)的第一键张量和第一值张量,以及列向聚合为1维(高度h=1)的第二键张量和第二值张量,这样可以将原本二维的注意力操作转换成两个一维的注意力操作,大大降低计算复杂度。
[0141]
示例性的,原本二维的注意力操作的计算复杂度o1为:
[0142]
o1=h2
×
w2
×
(h1
×
w1)
[0143]
聚合成行列分别计算的计算复杂度为:
[0144]
o2=h2
×
w2
×
(h1 w1)
[0145]
可见,计算复杂度从乘法变为了加法,对于图像来说,计算量大大降低,通常会降低1-2个数量级。
[0146]
本公开的图像处理方法,通过键向量和值向量的行列聚合,使得transformer等网络中的mha(multi-head attention,多头注意力)的计算量大大降低,也因此使得计算过程的内存消耗大大降低,从而大大提高图像处理效率。
[0147]
本公开上述各实施例或可选示例可以单独实施也可以在不冲突的情况下以任意组合方式结合实施,具体可以根据实际需求设置,本公开不做限定。
[0148]
本公开实施例提供的任一种图像处理方法可以由任意适当的具有数据处理能力的设备执行,包括但不限于:终端设备和服务器等。或者,本公开实施例提供的任一种图像处理方法可以由处理器执行,如处理器通过调用存储器存储的相应指令来执行本公开实施例提及的任一种图像处理方法。下文不再赘述。
[0149]
示例性装置
[0150]
图12是本公开一示例性实施例提供的图像处理装置的结构示意图。该实施例的装置可用于实现本公开相应的方法实施例,如图12所示的装置包括:第一确定模块501、第一
处理模块502、第二处理模块503、第三处理模块504、第四处理模块505、第五处理模块506和第六处理模块507。
[0151]
第一确定模块501,用于确定待处理图像对应的第一张量;第一处理模块502,用于基于第一确定模块501确定的所述第一张量,确定所述第一张量对应的行向聚合的第一键张量、列向聚合的第二键张量、行向聚合的第一值张量、及列向聚合的第二值张量;第二处理模块503,用于基于第二张量,确定查询张量,所述第二张量为待与所述第一张量进行交叉注意力操作的张量;第三处理模块504,用于基于所述第一键张量和所述查询张量进行注意力操作,获得第一注意力权重;第四处理模块505,用于基于所述第二键张量和所述查询张量进行注意力操作,获得第二注意力权重;第五处理模块506,用于基于所述第一注意力权重、所述第一值张量、所述第二注意力权重及所述第二值张量,确定目标输出张量;第六处理模块507,用于基于第五处理模块506确定的所述目标输出张量,确定所述待处理图像对应的图像处理结果。
[0152]
在一个可选示例中,图13是本公开一示例性实施例提供的第一处理模块502的结构示意图。本示例中,第一处理模块502包括:第一确定单元5021a、第二确定单元5022a、第三确定单元5023a、第四确定单元5024a和第五确定单元5025a。
[0153]
第一确定单元5021a,用于基于所述第一张量,确定行向聚合的第一聚合张量、及列向聚合的第二聚合张量;第二确定单元5022a,用于基于所述第一聚合张量及第一映射规则,确定所述第一键张量;第三确定单元5023a,用于基于所述第二聚合张量及第二映射规则,确定所述第二键张量;第四确定单元5024a,用于基于所述第一聚合张量及第三映射规则,确定所述第一值张量;第五确定单元5025a,用于基于所述第二聚合张量及第四映射规则,确定所述第二值张量。
[0154]
在一个可选示例中,第一确定单元5021a具体用于:对所述第一张量在行向上进行第一预设池化操作,确定所述第一聚合张量;对所述第一张量在列向上进行第二预设池化操作,确定所述第二聚合张量。
[0155]
在一个可选示例中,图14是本公开另一示例性实施例提供的第一处理模块502的结构示意图。在本示例中,第一处理模块502包括:第一处理单元5021b、第二处理单元5022b、第三处理单元5023b、第四处理单元5024b和第五处理单元5025b。
[0156]
第一处理单元5021b,用于基于所述第一张量,确定第三键张量及第三值张量;第二处理单元5022b,用于对所述第三键张量在行向进行聚合操作,获得所述第一键张量;第三处理单元5023b,用于对所述第三键张量在列向进行聚合操作,获得所述第二键张量;第四处理单元5024b,用于对所述第三值张量在行向进行聚合操作,获得所述第一值张量;第五处理单元5025b,用于对所述第三值张量在列向进行聚合操作,获得所述第二值张量。
[0157]
图15是本公开另一示例性实施例提供的图像处理装置的结构示意图。
[0158]
在一个可选示例中,所述第三处理模块504包括:第六处理单元5041和第六确定单元5042。
[0159]
第六处理单元5041,用于针对所述查询张量中的任一第一位置的c维向量,将该c维向量与所述第一键张量中每个第二位置的c维向量的转置相乘,获得该第一位置对应的权重值,c表示所述查询张量和所述第一键张量的通道数量;第六确定单元5042,用于基于各所述第一位置分别对应的权重值,确定所述第一注意力权重。
[0160]
在一个可选示例中,所述第四处理模块505包括:第七处理单元5051和第七确定单元5052
[0161]
第七处理单元5051,用于针对所述查询张量中的任一第一位置的c维向量,将该c维向量与所述第二键张量中每个第三位置的c维向量的转置相乘,获得该第一位置对应的权重值,c表示所述查询张量和所述第二键张量的通道数量;第七确定单元5052,用于基于各所述第一位置分别对应的权重值,确定所述第二注意力权重。
[0162]
在一个可选示例中,所述第五处理模块506包括:第八确定单元5061、第九确定单元5062和第十确定单元5063。
[0163]
第八确定单元5061,用于基于所述第一注意力权重及所述第一值张量,确定第一输出张量;第九确定单元5062,用于基于所述第二注意力权重及所述第二值张量,确定第二输出张量;第十确定单元5063,用于基于所述第一输出张量和所述第二输出张量,确定所述目标输出张量。
[0164]
在一个可选示例中,第十确定单元5063具体用于:将所述第一输出张量与所述第二输出张量相加,获得所述目标输出张量。
[0165]
在一个可选示例中,第二处理模块503包括:映射单元5031,用于基于所述第二张量及第五映射规则,确定所述查询张量。
[0166]
在一个可选示例中,所述第六处理模块507包括:第八处理单元5071、归一化单元5072和第九处理单元5073。
[0167]
第八处理单元5071,用于将所述目标输出张量与所述第二张量相加,获得第三张量;归一化单元5072,用于对所述第三张量进行归一化,获得第四张量;第九处理单元5073,用于基于所述第四张量,确定所述待处理图像对应的所述图像处理结果。
[0168]
在一个可选示例中,第一确定模块501包括:特征提取单元5011和第十处理单元5012。
[0169]
特征提取单元5011,用于对所述待处理图像进行特征提取,获得所述待处理图像对应的第一图像特征;第十处理单元5012,用于基于所述第一图像特征及所述第一图像特征对应的空间位置编码张量,确定所述第一张量。
[0170]
示例性电子设备
[0171]
本公开实施例还提供了一种电子设备,包括:存储器,用于存储计算机程序;
[0172]
处理器,用于执行所述存储器中存储的计算机程序,且所述计算机程序被执行时,实现本公开上述任一实施例所述的图像处理方法。
[0173]
图16是本公开电子设备一个应用实施例的结构示意图。本实施例中,该电子设备10包括一个或多个处理器11和存储器12。
[0174]
处理器11可以是中央处理单元(cpu)或者具有数据处理能力和/或指令执行能力的其他形式的处理单元,并且可以控制电子设备10中的其他组件以执行期望的功能。
[0175]
存储器12可以包括一个或多个计算机程序产品,所述计算机程序产品可以包括各种形式的计算机可读存储介质,例如易失性存储器和/或非易失性存储器。所述易失性存储器例如可以包括随机存取存储器(ram)和/或高速缓冲存储器(cache)等。所述非易失性存储器例如可以包括只读存储器(rom)、硬盘、闪存等。在所述计算机可读存储介质上可以存储一个或多个计算机程序指令,处理器11可以运行所述程序指令,以实现上文所述的本公
开的各个实施例的方法以及/或者其他期望的功能。在所述计算机可读存储介质中还可以存储诸如输入信号、信号分量、噪声分量等各种内容。
[0176]
在一个示例中,电子设备10还可以包括:输入装置13和输出装置14,这些组件通过总线系统和/或其他形式的连接机构(未示出)互连。
[0177]
例如,该输入装置13可以是上述的麦克风或麦克风阵列,用于捕捉声源的输入信号。
[0178]
此外,该输入装置13还可以包括例如键盘、鼠标等等。
[0179]
该输出装置14可以向外部输出各种信息,包括确定出的距离信息、方向信息等。该输出装置14可以包括例如显示器、扬声器、打印机、以及通信网络及其所连接的远程输出设备等等。
[0180]
当然,为了简化,图16中仅示出了该电子设备10中与本公开有关的组件中的一些,省略了诸如总线、输入/输出接口等等的组件。除此之外,根据具体应用情况,电子设备10还可以包括任何其他适当的组件。
[0181]
示例性计算机程序产品和计算机可读存储介质
[0182]
除了上述方法和设备以外,本公开的实施例还可以是计算机程序产品,其包括计算机程序指令,所述计算机程序指令在被处理器运行时使得所述处理器执行本说明书上述“示例性方法”部分中描述的根据本公开各种实施例的方法中的步骤。
[0183]
所述计算机程序产品可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例操作的程序代码,所述程序设计语言包括面向对象的程序设计语言,诸如java、c 等,还包括常规的过程式程序设计语言,诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。
[0184]
此外,本公开的实施例还可以是计算机可读存储介质,其上存储有计算机程序指令,所述计算机程序指令在被处理器运行时使得所述处理器执行本说明书上述“示例性方法”部分中描述的根据本公开各种实施例的方法中的步骤。
[0185]
所述计算机可读存储介质可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以包括但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。
[0186]
以上结合具体实施例描述了本公开的基本原理,但是,需要指出的是,在本公开中提及的优点、优势、效果等仅是示例而非限制,不能认为这些优点、优势、效果等是本公开的各个实施例必须具备的。另外,上述公开的具体细节仅是为了示例的作用和便于理解的作用,而非限制,上述细节并不限制本公开为必须采用上述具体的细节来实现。
[0187]
本说明书中各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似的部分相互参见即可。对于系统实施例而言,由于其与方法实施例基本对应,所以描述的比较简单,相关之处参见方法实施例的部
分说明即可。
[0188]
本公开中涉及的器件、装置、设备、系统的方框图仅作为例示性的例子并且不意图要求或暗示必须按照方框图示出的方式进行连接、布置、配置。如本领域技术人员将认识到的,可以按任意方式连接、布置、配置这些器件、装置、设备、系统。诸如“包括”、“包含”、“具有”等等的词语是开放性词汇,指“包括但不限于”,且可与其互换使用。这里所使用的词汇“或”和“和”指词汇“和/或”,且可与其互换使用,除非上下文明确指示不是如此。这里所使用的词汇“诸如”指词组“诸如但不限于”,且可与其互换使用。
[0189]
可能以许多方式来实现本公开的方法和装置。例如,可通过软件、硬件、固件或者软件、硬件、固件的任何组合来实现本公开的方法和装置。用于所述方法的步骤的上述顺序仅是为了进行说明,本公开的方法的步骤不限于以上具体描述的顺序,除非以其它方式特别说明。此外,在一些实施例中,还可将本公开实施为记录在记录介质中的程序,这些程序包括用于实现根据本公开的方法的机器可读指令。因而,本公开还覆盖存储用于执行根据本公开的方法的程序的记录介质。
[0190]
还需要指出的是,在本公开的装置、设备和方法中,各部件或各步骤是可以分解和/或重新组合的。这些分解和/或重新组合应视为本公开的等效方案。
[0191]
提供所公开的方面的以上描述以使本领域的任何技术人员能够做出或者使用本公开。对这些方面的各种修改对于本领域技术人员而言是非常显而易见的,并且在此定义的一般原理可以应用于其他方面而不脱离本公开的范围。因此,本公开不意图被限制到在此示出的方面,而是按照与在此公开的原理和新颖的特征一致的最宽范围。
[0192]
为了例示和描述的目的已经给出了以上描述。此外,此描述不意图将本公开的实施例限制到在此公开的形式。尽管以上已经讨论了多个示例方面和实施例,但是本领域技术人员将认识到其某些变型、修改、改变、添加和子组合。
再多了解一些

本文用于创业者技术爱好者查询,仅供学习研究,如用于商业用途,请联系技术所有人。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献