编码器的生成方法、指纹提取方法、介质及电子设备与流程

文档序号:29945442发布日期:2022-05-07 16:00阅读:87来源:国知局
编码器的生成方法、指纹提取方法、介质及电子设备与流程

1.本公开涉及人工智能技术领域,具体地,涉及一种编码器的生成方法、指纹提取方法、介质及电子设备。


背景技术:

2.音频指纹是从音频内容中提取出的代表一条音频重要声学信息的紧致数字签名。音频指纹为音频提供了一种唯一性的表示,通过音频指纹可以有效地将一条音频和其他音频区分开来。相关技术中,使用长短期记忆的自动编码器为音频生成音频指纹,并利用该音频指纹完成音频检索任务,例如,从曲库中检索出与该音频相关的其他音频。然而,针对失真音频,通过自动编码器生成的音频指纹无法有效表示该音频,进而降低了音频检索的准确率,无法有效地完成音频检索任务。


技术实现要素:

3.提供该部分内容以便以简要的形式介绍构思,这些构思将在后面的具体实施方式部分被详细描述。该部分内容并不旨在标识要求保护的技术方案的关键特征或必要特征,也不旨在用于限制所要求的保护的技术方案的范围。
4.第一方面,本公开提供一种编码器的生成方法,包括:
5.获取多个样本音频;
6.根据所述多个样本音频构造第一组样本以及第一组样本,其中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;
7.根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;
8.其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
9.第二方面,本公开提供一种音频指纹提取方法,包括:
10.获取待查询音频;
11.根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据第一方面所述的编码器的生成方法训练完成的第一编码器。
12.第三方面,本公开提供一种编码器的生成装置,包括:
13.第一获取模块,被配置为获取多个样本音频;
14.构造模块,被配置为根据所述多个样本音频构造第一组样本以及第一组样本,其
中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;
15.训练模块,被配置为根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;
16.其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
17.第四方面,本公开提供一种音频指纹提取装置,包括:
18.第二获取模块,被配置为获取待查询音频;
19.处理模块,被配置为根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据第一方面所述的编码器的生成方法训练完成的第一编码器。
20.第五方面,本公开提供一种计算机可读介质,其上存储有计算机程序,该程序被处理装置执行时实现第一方面和第二方面所述方法的步骤。
21.第六方面,本公开提供一种电子设备,包括:
22.存储装置,其上存储有至少一个计算机程序;
23.至少一个处理装置,用于执行所述存储装置中的所述至少一个计算机程序,以实现第一方面和第二方面所述方法的步骤。
24.通过上述技术方案,通过对比训练的方式,使第一编码器输出的第一编码向量接近对应的正样本的第二编码向量,远离对应的负样本的第二编码向量,即使得第一编码器输出的编码向量能更有效地区分与其属于同一个音频的音频以及与其不属于同一个音频的音频,且对比训练使得第一编码器能学习到音频的更高层次的特征。进而训练得到的作为音频指纹提取器的第一编码器输出的音频指纹(即输出的音频的指纹特征的编码向量)能更好地完成音频检索任务,提高了音频检索的准确度。
25.本公开的其他特征和优点将在随后的具体实施方式部分予以详细说明。
附图说明
26.结合附图并参考以下具体实施方式,本公开各实施例的上述和其他特征、优点及方面将变得更加明显。贯穿附图中,相同或相似的附图标记表示相同或相似的元素。应当理解附图是示意性的,原件和元素不一定按照比例绘制。在附图中:
27.图1是根据本公开一示例性实施例示出的一种编码器的生成方法的流程图。
28.图2是根据本公开一示例性实施例示出的对第一编码器以及第二编码器进行对比训练的流程图。
29.图3是根据本公开一示例性实施例示出的一种音频指纹提取方法的流程图。
30.图4是根据本公开一示例性实施例示出的一种编码器的生成装置的框图。
31.图5是根据本公开一示例性实施例示出的一种音频指纹提取装置的框图。
32.图6是根据本公开一示例性实施例示出的一种电子设备的结构示意图。
具体实施方式
33.下面将参照附图更详细地描述本公开的实施例。虽然附图中显示了本公开的某些实施例,然而应当理解的是,本公开可以通过各种形式来实现,而且不应该被解释为限于这里阐述的实施例,相反提供这些实施例是为了更加透彻和完整地理解本公开。应当理解的是,本公开的附图及实施例仅用于示例性作用,并非用于限制本公开的保护范围。
34.应当理解,本公开的方法实施方式中记载的各个步骤可以按照不同的顺序执行,和/或并行执行。此外,方法实施方式可以包括附加的步骤和/或省略执行示出的步骤。本公开的范围在此方面不受限制。
35.本文使用的术语“包括”及其变形是开放性包括,即“包括但不限于”。术语“基于”是“至少部分地基于”。术语“一个实施例”表示“至少一个实施例”;术语“另一实施例”表示“至少一个另外的实施例”;术语“一些实施例”表示“至少一些实施例”。其他术语的相关定义将在下文描述中给出。
36.需要注意,本公开中提及的“第一”、“第二”等概念仅用于对不同的装置、模块或单元进行区分,并非用于限定这些装置、模块或单元所执行的功能的顺序或者相互依存关系。
37.需要注意,本公开中提及的“一个”、“多个”的修饰是示意性而非限制性的,本领域技术人员应当理解,除非在上下文另有明确指出,否则应该理解为“一个或多个”。
38.本公开实施方式中的多个装置之间所交互的消息或者信息的名称仅用于说明性的目的,而并不是用于对这些消息或信息的范围进行限制。
39.正如背景技术所言,音频指纹是从音频内容中提取出的代表一条音频重要声学信息的紧致数字签名。音频指纹为音频提供了一种唯一性的表示,通过音频指纹可以有效地将一条音频和其他音频区分开来。在一些实施例中,音频指纹可以应用于多种场景,例如,音频指纹可以用于音频消重,即消除一组音频中的重复音频;又例如,音频指纹可以用于音频检索,如用于听歌识曲,为一段音频找出其原曲。
40.相关技术中,在音频检索任务中,可以基于非深度学习的算法,对原始音频提取频谱图后,计算频谱图上的显著点,对其进行哈希编码,构建大规模音频指纹库,检索时对查询音频提取指纹特征后,通过哈希特征检索进行多级过滤。也可以通过音乐检测模块和音乐识别模块进行音频检索,其中,音乐检测模块用于检测当前是否有音乐,音乐识别模块包含一些卷积层和两层分割编码块,其对查询音频提取特征,并通过特征距离进行检索。除此之外,还可以使用一个长短期记忆的自动编码器生成音频指纹,利用该音频指纹进行音频检索。
41.然而,上述相关技术中所述的生成音频指纹(或提取特征)的方法,均不能对失真音频进行有效检索。在一些实施例中,失真音频可以是指被编辑后的音频,例如,对音频的速度和/或音频进行编辑后得到的音频。
42.有鉴于此,本公开提出一种编码器的生成方法,通过对比训练的方式训练得到作为音频指纹提取器的第一编码器,使得第一编码器能学习到音频的更高层次的特征,其输出的编码向量能更好地区分与其属于同一个音频的音频以及与其不属于同一个音频的音频,通过该音频指纹提取器输出的音频指纹能更好地完成音频检索任务,提高音频检索的
准确度。
43.图1是根据本公开一示例性实施例示出的一种编码器的生成方法的流程图。如图1所示,该生成方法包括:
44.步骤110,获取多个样本音频。
45.在一些实施例,样本音频可以是用于对第一编码器和第二编码器进行对比训练的训练数据。在一些实施例中,样本音频可以是音乐数据,例如,歌曲或歌曲片段,其中,歌曲片段的长度可以根据实际情况具体设置,例如,歌曲片段的长度可以是10s至900s中的任意数值。在一些实施例中,样本音频可以使用不同人声和不同风格的音乐数据。
46.在一些实施例中,可以通过读取存储的数据、调用相关接口或其他方式获取多个样本音频。
47.步骤120,根据多个样本音频构造第一组样本以及第一组样本。
48.在一些实施例中,可以根据多个样本音频的数据增强的结果构造第一组样本以及第一组样本,数据增强可以包括对音频的参数进行调整。在一些实施例中,根据多个样本音频构造第一组样本以及第一组样本,包括:对多个样本音频分别进行第一参数调整以及第二参数调整,得到第一组样本以及第一组样本。
49.在一些实施例中,参数调整可以是指根据对应的调整方式对音频的调整参数进行调整。在一些实施例中,第一参数调整或第二参数调整的调整参数可以包括但不限于以下的至少一种:噪声、音高、速度、滤波参数、回声、增益或衰减的频段、以及音频格式。
50.在一些实施例中,噪声可以包括白噪声,对噪声进行调整可以是指增加第一预设比例的白噪声,其中,第一预设比例可以根据实际情况具体设置,例如,第一预设比例的范围可以是(0,0.1]。在一些实施例中,对音高进行调整可以是指对音高进行升调或降调,例如,在八度内对音高进行升调或降调,八度可以包括12个半音,对应的,对音高进行调整可以是指以半音为单位对八度内的音高进行升调或降调。
51.在一些实施例中,对速度进行调整可以是指根据第二预设倍速对音频的播放速度进行快进或慢放,其中,第二预设倍速可以根据实际情况具体设置,例如,第二预设倍速的范围可以是[0.5,1.5]。在一些实施例中,滤波参数可以是指滤波频率,对滤波参数进行调整可以是指对音频进行高通滤波和/或低通滤波,其中,高通滤波或低通滤波对应的滤波频率可以根据实际需求进行具体设置。例如,高通滤波的滤波频率可以是2000hz,低通滤波的滤波频率可以是300hz。
[0052]
在一些实施例中,对增益或衰减的频段进行调整可以通过均衡器实现,均衡器可以对以下参数进行调整:频率、增益以及q(quantize)值,其中,频率可以是用于表征进行调整的频率点的参数,增益可以是用于表征在设定的频率值上进行增益或衰减的参数,q值可以是用于表征进行增益或衰减的频段“宽度”的参数。在一些实施例中,对音频格式进行调整可以是指通过预设格式对音频进行压缩,预设格式可以根据实际情况具体设置。例如,预设格式可以是32kbps的mp3格式。在一些实施例中,还可以通过对音频的其他参数进行调整实现数据增强,例如,增加高斯噪声等,本公开在此不再赘述。
[0053]
在一些实施例中,第一参数调整和第二参数调整对应的调整参数和/或调整方式不完全相同。调整方式不同可以是指调整参数的设定值不同。示例地,第一参数调整可以是增加0.1比例的白噪声、对音频播放速度加快0.5倍、以及对音频前两个半音进行升调。第二
参数调整可以是增加0.2比例的白噪声、对音频播放速度加快1倍、对音频的前2个半音进行升调,第三个半音进行降调、以及2000hz高通滤波。通过调整参数和/或调整方式不完全相同的第一参数调整和第二参数调整可以实现不同版本的数据增强。
[0054]
在一些实施例中,第一组样本中的每一条样本为经过第一参数调整后的样本音频,第一组样本中的每一条样本为经过第二参数调整后的样本音频。在一些实施例中,对样本音频采用不同版本的数据增强得到的音频互为相似音频,即对同一样本音频进行第一参数调整和第二参数调整,得到的第一参数调整后的样本音频和第二参数调整后的样本音频互为相似音频。
[0055]
可以理解的,针对第一组样本中的任一样本,该样本的相似音频为该样本的正样本,不相似音频为该样本的负样本。因此,针对第一组样本中的每一条样本,在第一组样本中均存在对应的正样本以及负样本。对应的,针对第一组样本中的每一条样本,第一组样本中与该样本对应相同样本音频的样本为正样本,其他样本为负样本。
[0056]
在本公开实施例中,调整参数的类型多样,通过对多种调整参数进行调整分别得到第一组样本和第一组样本,进而通过该第一组样本和第一组样本对第一编码器和第二编码器进行对比训练,第一编码器能处理对多种调整参数进行调整后的音频,即第一编码器能处理被多种方式编辑后的音频,提高了第一编码器的鲁棒性,使得第一编码器能更好地提取被编辑的音频(例如,音高和/或速度进行调整的音频)的音频指纹,即能更好地提取失真音频的音频指纹,进而针对失真音频,利用第一编码器输出的音频指纹能准确地完成音频检索任务,提高音频检索的准确度。
[0057]
步骤130,根据第一组样本和第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量。
[0058]
在一些实施例中,第一编码器用于对第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,第二编码器用于对第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量。在一些实施例中,第一编码器可以用于对第一组样本中的样本的梅尔频谱进行编码处理,得到对应每一条样本的第一编码向量,第二编码器可以用于对第一组样本中的样本的梅尔频谱进行编码处理,得到对应每一条样本的第二编码向量。在一些实施例中,第一编码器可以是编码器,第二编码器可以是动量编码器。在一些实施例中,第一编码器或第二编码器可以是残差网络,例如,resnet18。
[0059]
在一些实施例中,对比训练用于使第一编码器输出的第一编码向量接近对应的正样本的第二编码向量,远离对应的负样本的第二编码向量,且第二编码器的编码参数逐渐趋向第一编码器的编码参数。对比训练可以是自监督学习,自监督学习无需人工标注的标签信息,直接利用数据本身作为监督信息,来学习样本数据(例如,样本音频)的特征表达。关于对第一编码器和第二编码器进行对比训练的具体细节可以参见图2及其相关描述,在此不再赘述。
[0060]
在本公开的实施例中,通过对比训练使第一编码器输出的第一编码向量接近对应的正样本的第二编码向量,远离对应的负样本的第二编码向量,即使得样本音频的特征与其正样本的特征更相似,且与其负样本的特征更不相似,从而使得编码器输出的第一编码向量能更有效地区分与其属于同一个音频的音频以及与其不属于同一个音频的音频,且对
比训练使得第一编码器能学习到音频的更高层次的特征。进而,训练得到的作为音频指纹提取器的第一编码器输出的音频指纹(即输出的音频的指纹特征的编码向量)能更好地完成音频检索任务,提高了音频检索的准确度。
[0061]
图2是根据本公开一示例性实施例示出的对第一编码器以及第二编码器进行对比训练的流程图。如图2所示,该方法包括:
[0062]
步骤210,根据第一编码器对第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,以及根据第二编码器对第一组样本的样本进行编码,得到对应每一条样本的第二编码向量。
[0063]
步骤220,基于第一编码向量和第二编码向量对对比损失函数的损失值进行迭代运算,并基于损失值迭代更新第一编码器的编码参数,以使第一编码器输出的第一编码向量接近对应的正样本的第二编码向量,远离对应的负样本的第二编码向量,其中,损失值用于表征第一编码向量以及第二编码向量之间的相似度;并,使第二编码器的编码参数逐渐趋向第一编码器的编码参数,直到得到训练完成的第一编码器。
[0064]
在一些实施例中,相似度可以通过向量之间的距离确定,距离越小,相似度越大。在一些实施例中,距离可以包括但不限于余弦距离、欧氏距离、曼哈顿距离、马氏距离或闵可夫斯基距离等。
[0065]
在一些实施例中,可以根据实际情况确定对比损失函数,并利用该对比损失函数确定损失值。例如,将第一编码向量和第二编码向量之间的相似度确定为损失值。在一些实施例中,对比损失函数可以是infonce(noise contrastive estimation,infonce)损失函数。在一些实施例中,infonce损失函数的损失值可以通过如下公式(1)得到:
[0066][0067]
其中,lq表示infonce损失函数的损失值,q表示第一编码向量,k
+
表示与第一编码向量对应的样本匹配的正样本的第二编码向量,τ表示温度超参,τ可以根据实际情况具体设置,例如,τ可以是0.1,k表示参与损失值计算的第二编码向量的总和,ki表示参与损失值计算的第i个第二编码向量,q
·k+
表示q与k
+
的点积,q
·ki
表示q与ki的点积,exp表示以自然常数e为底的指数函数,log表示对数函数。
[0068]
在一些实施例中,基于第一编码向量和第二编码向量对对比损失函数的损失值进行迭代运算,包括:在迭代运算是第一轮的情况下,基于第一轮得到的第一编码向量和第二编码向量,确定对比损失函数的损失值;在迭代运算不是第一轮的情况下,根据当前轮得到的第二编码向量替换掉预设队列中目标历史轮对应的第二编码向量,并基于当前轮得到的第一编码向量和预设队列中的第二编码向量,确定对比损失函数的所述损失值;其中,预设队列用于存储迭代运算中每一轮得到的第二编码向量,目标历史轮为预设队列中存储的轮数最早的历史轮。
[0069]
在一些实施例中,在迭代运算是第一轮的情况下,预设队列中可以存储第一轮得到的第二编码向量,可以理解的,在迭代运算是第一轮的情况下,基于第一轮得到的第一编码向量和第二编码向量确定损失值,也即基于第一轮得到的第一编码向量和预设队列中的第二编码向量确定损失值。在迭代运算不是第一轮的情况下,可以根据当前轮得到的第二编码向量替换掉预设队列中目标历史轮对应的第二编码向量,即对预设队列进行更新,进
而基于当前轮得到的第一编码向量和更新后的预设队列中的第二编码向量,确定对比损失函数的所述损失值。由此可知,在损失值的迭代运算过程中,预设队列为动态队列,预设队列中的第二编码向量在每一轮迭代运算时会进行更新,且在每一轮迭代运算中,针对多个第一编码中的每个,在预设队列中存在1个正样本的第二编码向量,其余为负样本的第二编码向量。
[0070]
示例地,以多个样本音频为n个样本音频为例,则第一编码器可以得到n个第一编码向量,第二编码器可以得到n个第二编码向量,在模型的损失值的迭代运算过程中,在迭代运算是第一轮的情况下,可以基于第一轮得到的n个第二编码向量(也即预设队列中存储的第一轮得到的n个编码向量)和第一轮得到的n个第一编码向量,确定对比损失函数的损失值,例如,针对第一轮的n个第一编码向量中的每个,利用该第一编码向量和n个第二编码向量通过上述公式(1)计算得到n个损失值,对n个损失值求平均得到第一轮迭代运算的损失值。在迭代运算不是第一轮的情况下,例如,迭代运算为第二轮,则可以根据第二轮得到的n个第二编码向量替换掉预设队列中存储的轮数最早的历史轮,即第一轮得到的n个第二编码向量,此时预设队列中包括替换后的n个第二编码向量,进而,可以通过第二轮得到的n个第一编码向量和该预设队列中的n个第二编码向量,确定对比损失函数的损失值,得到第二轮迭代运算的损失值的方式与第一轮类似,在此不再赘述。以此类推,可以得到多轮迭代运算中每轮对应的损失值。
[0071]
在一些实施例中,基于损失值迭代更新第一编码器的编码参数的过程中,第二编码器的编码参数逐渐趋向第一编码器的编码参数。在一些实施例中,第二编码器的编码参数可以通过如下公式(2)进行变化:
[0072]
θk←
mθk+(1-m)θq(2)
[0073]
其中,θk表示第二编码器的编码参数,θq表示第一编码器的编码参数,m表示常数,m可以根据实际情况具体设置,例如,m=0.999。由于m设置的值较大,因此,第二编码器的编码参数保持了其本身的大部分权重,仅利用较小的权重往第一编码器的编码参数进行靠近,实现第二编码器的编码参数逐渐趋向第一编码器的编码参数。
[0074]
图3是根据本公开一示例性实施例示出的一种音频指纹提取方法的流程图。如图3所示,该方法包括:
[0075]
步骤310,获取待查询音频。
[0076]
步骤320,根据音频指纹提取器对待查询音频进行处理,得到作为待查询音频的指纹特征的编码向量。
[0077]
在一些实施例中,待查询音频可以是需要得到音频的指纹特征的编码向量的音频,即需要得到音频指纹的音频。在一些实施例中,待查询音频可以是失真音频,即被编辑后的音频。在一些实施例中,被编辑的音频可以是指对以下一种或多种调整参数进行调整后的得到音频:噪声、音高、速度、滤波参数、回声、增益或衰减的频段、以及音频格式。关于调整前述调整参数的具体细节可以参见上述步骤120及其相关描述,在此不再赘述。
[0078]
在一些实施例中,音频指纹提取器可以是根据前述步骤110至步骤130得到的训练完成的第一编码器。关于第一编码器(即音频指纹提取器)的训练过程可以参见上述图1和图2及其相关描述,在此不再赘述。
[0079]
在一些实施例中,根据待查询音频的指纹特征的编码向量,即根据待查询音频的
音频指纹,可以完成音频检索任务。在一些实施例中,根据待查询音频的音频指纹可以从预设数据库中检索出与该待查询音频属于同一音频的其他音频。示例地,当待查询音频为失真歌曲时,音频检索任务可以是指从曲库中检索出该待查询音频的原曲。
[0080]
在一些实施例中,根据待查询音频的音频指纹从预设数据库中检索出与该待查询音频属于同一音频的其他音频可以是:根据待查询音频的音频指纹,从数据库中检索出与该音频指纹的相似度满足预设条件的其他音频。相似度可以通过音频指纹,即音频的指纹特征的编码向量之间的距离确定。关于距离可以参见上述步骤210及其相关描述,在此不再赘述。值得说明的是,还可以通过除相似度以外的其他方式,从数据库中检索出与待查询音频属于同一音频的其他音频,本公开对此并不做任何限制。
[0081]
图4是根据本公开一示例性实施例示出的一种编码器的生成装置的框图。如图4所示,该生成装置400包括:
[0082]
第一获取模块410,被配置为获取多个样本音频;
[0083]
构造模块420,被配置为根据所述多个样本音频构造第一组样本以及第一组样本,其中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;
[0084]
训练模块430,被配置为根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;
[0085]
其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
[0086]
在一些实施例中,构造模块420进一步被配置为:
[0087]
对多个所述样本音频分别进行第一参数调整以及第二参数调整,得到所述第一组样本以及所述第一组样本,所述第一参数调整和所述第二参数调整对应的调整参数和/或调整方式不完全相同;
[0088]
其中,所述第一组样本中的每一条样本为经过所述第一参数调整后的样本音频,所述第一组样本中的每一条样本为经过所述第二参数调整后的样本音频,针对所述第一组样本中的每一条样本,所述第一组样本中与该样本对应相同样本音频的样本为正样本,其他样本为负样本。
[0089]
在一些实施例中,所述调整参数包括但不限于以下的一种或多种:噪声、音高、速度、滤波参数、回声、增益或衰减的频段、以及音频格式。
[0090]
在一些实施例中,训练模块430进一步被配置为:
[0091]
根据所述第一编码器对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,以及根据所述第二编码器对所述第一组样本的样本进行编码,得到对应每一条样本的第二编码向量;
[0092]
基于所述第一编码向量和所述第二编码向量对对比损失函数的损失值进行迭代运算,并基于所述损失值迭代更新所述第一编码器的编码参数,以使所述第一编码器输出
的所述第一编码向量接近对应的所述正样本的所述第二编码向量,远离对应的所述负样本的所述第二编码向量,其中,所述损失值用于表征所述第一编码向量以及所述第二编码向量之间的相似度;并,
[0093]
使所述第二编码器的编码参数逐渐趋向所述第一编码器的所述编码参数,直到得到训练完成的所述第一编码器。
[0094]
在一些实施例中,训练模块430进一步被配置为:
[0095]
在所述迭代运算是第一轮的情况下,基于所述第一轮得到的所述第一编码向量和所述第二编码向量,确定所述对比损失函数的所述损失值;
[0096]
在所述迭代运算不是所述第一轮的情况下,根据当前轮得到的所述第二编码向量替换掉预设队列中目标历史轮对应的所述第二编码向量,并基于所述当前轮得到的所述第一编码向量和所述预设队列中的所述第二编码向量,确定所述对比损失函数的所述损失值;
[0097]
其中,所述预设队列用于存储所述迭代运算中每一轮得到的所述第二编码向量,所述目标历史轮为所述预设队列中存储的轮数最早的所述历史轮。
[0098]
图5是根据本公开一示例性实施例示出的一种音频指纹提取装置的框图。如图5所示,该装置500包括:
[0099]
第二获取模块510,被配置为获取待查询音频;
[0100]
处理模块520,被配置为根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据本公开实施例所述的编码器的生成方法训练完成的第一编码器。
[0101]
下面参考图6,其示出了适于用来实现本公开实施例的电子设备600的结构示意图。本公开实施例中的终端设备可以包括但不限于诸如移动电话、笔记本电脑、数字广播接收器、pda(个人数字助理)、pad(平板电脑)、pmp(便携式多媒体播放器)、车载终端(例如车载导航终端)等等的移动终端以及诸如数字tv、台式计算机等等的固定终端。图6示出的电子设备仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
[0102]
如图6所示,电子设备600可以包括处理装置(例如中央处理器、图形处理器等)601,其可以根据存储在只读存储器(rom)602中的程序或者从存储装置608加载到随机访问存储器(ram)603中的程序而执行各种适当的动作和处理。在ram 603中,还存储有电子设备600操作所需的各种程序和数据。处理装置601、rom 602以及ram 603通过总线604彼此相连。输入/输出(i/o)接口605也连接至总线604。
[0103]
通常,以下装置可以连接至i/o接口605:包括例如触摸屏、触摸板、键盘、鼠标、摄像头、麦克风、加速度计、陀螺仪等的输入装置606;包括例如液晶显示器(lcd)、扬声器、振动器等的输出装置607;包括例如磁带、硬盘等的存储装置608;以及通信装置609。通信装置609可以允许电子设备600与其他设备进行无线或有线通信以交换数据。虽然图6示出了具有各种装置的电子设备600,但是应理解的是,并不要求实施或具备所有示出的装置。可以替代地实施或具备更多或更少的装置。
[0104]
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在非暂态计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这
样的实施例中,该计算机程序可以通过通信装置609从网络上被下载和安装,或者从存储装置608被安装,或者从rom 602被安装。在该计算机程序被处理装置601执行时,执行本公开实施例的方法中限定的上述功能。
[0105]
需要说明的是,本公开上述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑磁盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读信号介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:电线、光缆、rf(射频)等等,或者上述的任意合适的组合。
[0106]
在一些实施方式中,可以利用诸如http(hypertext transfer protocol,超文本传输协议)之类的任何当前已知或未来研发的网络协议进行通信,并且可以与任意形式或介质的数字数据通信(例如,通信网络)互连。通信网络的示例包括局域网(“lan”),广域网(“wan”),网际网(例如,互联网)以及端对端网络(例如,ad hoc端对端网络),以及任何当前已知或未来研发的网络。
[0107]
上述计算机可读介质可以是上述电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
[0108]
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:获取多个样本音频;根据所述多个样本音频构造第一组样本以及第一组样本,其中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
[0109]
或者,上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该电子设备执行时,使得该电子设备:获取待查询音频;根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据本公开实施例所述的编码器的生成方法训练完成的第一编码器。
[0110]
可以以一种或多种程序设计语言或其组合来编写用于执行本公开的操作的计算机程序代码,上述程序设计语言包括但不限于面向对象的程序设计语言—诸如java、smalltalk、c++,还包括常规的过程式程序设计语言——诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(lan)或广域网(wan)——连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
[0111]
附图中的流程图和框图,图示了按照本公开各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
[0112]
描述于本公开实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。其中,模块的名称在某种情况下并不构成对该模块本身的限定。
[0113]
本文中以上描述的功能可以至少部分地由一个或多个硬件逻辑部件来执行。例如,非限制性地,可以使用的示范类型的硬件逻辑部件包括:现场可编程门阵列(fpga)、专用集成电路(asic)、专用标准产品(assp)、片上系统(soc)、复杂可编程逻辑设备(cpld)等等。
[0114]
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦除可编程只读存储器(eprom或快闪存储器)、光纤、便捷式紧凑盘只读存储器(cd-rom)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
[0115]
根据本公开的一个或多个实施例,示例1提供了一种编码器的生成方法,包括:
[0116]
获取多个样本音频;
[0117]
根据所述多个样本音频构造第一组样本以及第一组样本,其中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;
[0118]
根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;
[0119]
其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一
条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
[0120]
根据本公开的一个或多个实施例,示例2提供了示例1的方法,所述根据所述多个样本音频构造第一组样本以及第一组样本,包括:
[0121]
对多个所述样本音频分别进行第一参数调整以及第二参数调整,得到所述第一组样本以及所述第一组样本,所述第一参数调整和所述第二参数调整对应的调整参数和/或调整方式不完全相同;
[0122]
其中,所述第一组样本中的每一条样本为经过所述第一参数调整后的样本音频,所述第一组样本中的每一条样本为经过所述第二参数调整后的样本音频,针对所述第一组样本中的每一条样本,所述第一组样本中与该样本对应相同样本音频的样本为正样本,其他样本为负样本。
[0123]
根据本公开的一个或多个实施例,示例3提供了示例2的方法,所述调整参数包括但不限于以下的一种或多种:噪声、音高、速度、滤波参数、回声、增益或衰减的频段、以及音频格式。
[0124]
根据本公开的一个或多个实施例,示例4提供了示例1的方法,所述根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,包括:
[0125]
根据所述第一编码器对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,以及根据所述第二编码器对所述第一组样本的样本进行编码,得到对应每一条样本的第二编码向量;
[0126]
基于所述第一编码向量和所述第二编码向量对对比损失函数的损失值进行迭代运算,并基于所述损失值迭代更新所述第一编码器的编码参数,以使所述第一编码器输出的所述第一编码向量接近对应的所述正样本的所述第二编码向量,远离对应的所述负样本的所述第二编码向量,其中,所述损失值用于表征所述第一编码向量以及所述第二编码向量之间的相似度;并,
[0127]
使所述第二编码器的编码参数逐渐趋向所述第一编码器的所述编码参数,直到得到训练完成的所述第一编码器。
[0128]
根据本公开的一个或多个实施例,示例5提供了示例4的方法,所述基于所述第一编码向量和所述第二编码向量对对比损失函数的损失值进行迭代运算,包括:
[0129]
在所述迭代运算是第一轮的情况下,基于所述第一轮得到的所述第一编码向量和所述第二编码向量,确定所述对比损失函数的所述损失值;
[0130]
在所述迭代运算不是所述第一轮的情况下,根据当前轮得到的所述第二编码向量替换掉预设队列中目标历史轮对应的所述第二编码向量,并基于所述当前轮得到的所述第一编码向量和所述预设队列中的所述第二编码向量,确定所述对比损失函数的所述损失值;
[0131]
其中,所述预设队列用于存储所述迭代运算中每一轮得到的所述第二编码向量,所述目标历史轮为所述预设队列中存储的轮数最早的所述历史轮。
[0132]
根据本公开的一个或多个实施例,示例6提供了一种音频指纹提取方法,包括:获
取待查询音频;根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据示例1-5任一项所述的编码器的生成方法训练完成的第一编码器。
[0133]
根据本公开的一个或多个实施例,示例7提供了一种编码器的生成装置,包括:
[0134]
第一获取模块,被配置为获取多个样本音频;
[0135]
构造模块,被配置为根据所述多个样本音频构造第一组样本以及第一组样本,其中,针对所述第一组样本中的每一条样本,在所述第一组样本中均存在对应的正样本以及负样本;
[0136]
训练模块,被配置为根据所述第一组样本和所述第一组样本对于第一编码器以及第二编码器进行对比训练,训练完成的所述第一编码器能够作为音频指纹提取器输出作为音频的指纹特征的编码向量;
[0137]
其中,所述第一编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,所述第二编码器用于对所述第一组样本中的样本进行编码,得到对应每一条样本的第二编码向量;所述对比训练用于使所述第一编码器输出的第一编码向量接近对应的所述正样本的第二编码向量,远离对应的所述负样本的第二编码向量,且所述第二编码器的编码参数逐渐趋向所述第一编码器的编码参数。
[0138]
根据本公开的一个或多个实施例,示例8提供了示例7的装置,所述构造模块进一步被配置为:
[0139]
对多个所述样本音频分别进行第一参数调整以及第二参数调整,得到所述第一组样本以及所述第一组样本,所述第一参数调整和所述第二参数调整对应的调整参数和/或调整方式不完全相同;
[0140]
其中,所述第一组样本中的每一条样本为经过所述第一参数调整后的样本音频,所述第一组样本中的每一条样本为经过所述第二参数调整后的样本音频,针对所述第一组样本中的每一条样本,所述第一组样本中与该样本对应相同样本音频的样本为正样本,其他样本为负样本。
[0141]
根据本公开的一个或多个实施例,示例9提供了示例8的装置,所述调整参数包括但不限于以下的至少一种:噪声、音高、速度、滤波参数、回声、增益或衰减的频段、以及音频格式。
[0142]
根据本公开的一个或多个实施例,示例10提供了示例7的装置,所述训练模块进一步被配置为:
[0143]
根据所述第一编码器对所述第一组样本中的样本进行编码,得到对应每一条样本的第一编码向量,以及根据所述第二编码器对所述第一组样本的样本进行编码,得到对应每一条样本的第二编码向量;
[0144]
基于所述第一编码向量和所述第二编码向量对对比损失函数的损失值进行迭代运算,并基于所述损失值迭代更新所述第一编码器的编码参数,以使所述第一编码器输出的所述第一编码向量接近对应的所述正样本的所述第二编码向量,远离对应的所述负样本的所述第二编码向量,其中,所述损失值用于表征所述第一编码向量以及所述第二编码向量之间的相似度;并,
[0145]
使所述第二编码器的编码参数逐渐趋向所述第一编码器的所述编码参数,直到得
到训练完成的所述第一编码器。
[0146]
根据本公开的一个或多个实施例,示例11提供了示例10的装置,所述训练模块进一步被配置为:
[0147]
在所述迭代运算是第一轮的情况下,基于所述第一轮得到的所述第一编码向量和所述第二编码向量,确定所述对比损失函数的所述损失值;
[0148]
在所述迭代运算不是所述第一轮的情况下,根据当前轮得到的所述第二编码向量替换掉预设队列中目标历史轮对应的所述第二编码向量,并基于所述当前轮得到的所述第一编码向量和所述预设队列中的所述第二编码向量,确定所述对比损失函数的所述损失值;
[0149]
其中,所述预设队列用于存储所述迭代运算中每一轮得到的所述第二编码向量,所述目标历史轮为所述预设队列中存储的轮数最早的所述历史轮。
[0150]
根据本公开的一个或多个实施例,示例12提供一种音频指纹提取装置,包括:
[0151]
第二获取模块,被配置为获取待查询音频;
[0152]
处理模块,被配置为根据音频指纹提取器对所述待查询音频进行处理,得到作为所述待查询音频的指纹特征的编码向量;所述音频指纹提取器是根据示例1-5任一项所述的编码器的生成方法训练完成的第一编码器。
[0153]
根据本公开的一个或多个实施例,示例13提供一种计算机可读介质,其上存储有计算机程序,该程序被处理装置执行时实现示例1-6中任一项所述方法的步骤。
[0154]
根据本公开的一个或多个实施例,示例14提供一种电子设备,包括:
[0155]
存储装置,其上存储有至少一个计算机程序;
[0156]
至少一个处理装置,用于执行所述存储装置中的所述至少一个计算机程序,以实现示例1-6中任一项所述方法的步骤。
[0157]
以上描述仅为本公开的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本公开中所涉及的公开范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述公开构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本公开中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
[0158]
此外,虽然采用特定次序描绘了各操作,但是这不应当理解为要求这些操作以所示出的特定次序或以顺序次序执行来执行。在一定环境下,多任务和并行处理可能是有利的。同样地,虽然在上面论述中包含了若干具体实现细节,但是这些不应当被解释为对本公开的范围的限制。在单独的实施例的上下文中描述的某些特征还可以组合地实现在单个实施例中。相反地,在单个实施例的上下文中描述的各种特征也可以单独地或以任何合适的子组合的方式实现在多个实施例中。
[0159]
尽管已经采用特定于结构特征和/或方法逻辑动作的语言描述了本主题,但是应当理解所附权利要求书中所限定的主题未必局限于上面描述的特定特征或动作。相反,上面所描述的特定特征和动作仅仅是实现权利要求书的示例形式。关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1