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

一种模型训练和业务执行的方法、装置、介质及设备与流程

2022-12-10 20:16:08 来源:中国专利 TAG:


1.本说明书涉及计算机技术领域,尤其涉及一种模型训练和业务执行的方法、装置、介质及设备。


背景技术:

2.随着科技的发展,人机交互技术也在诸如智能客服、智能对话机器人等领域得到了广泛的应用,对于用户输入的语音数据,交互系统通常会通过相应的模型算法,来对语音数据所表达的情感(如愤怒、恐惧、悲伤以及厌恶等)进行识别,进而根据识别到的情感执行与之相匹配的交互动作。
3.然而,目前在对用户输入的语音进行情感识别的过程中,通常只会识别出语音数据的情感类型,识别到的结果较为单一,并不能完全表达出用户当前的情绪,这就会导致后续执行的交互动作效果较差,严重影响了用户体验。
4.因此,如何根据识别模型的识别结果准确的执行相应的业务,提高用户体验,是一个亟待解决的问题。


技术实现要素:

5.本说明书提供一种模型训练和业务执行的方法、装置、介质及设备,以部分的解决现有技术存在的上述问题。
6.本说明书采用下述技术方案:本说明书提供了一种模型训练的方法,包括:获取用户在历史上执行客服业务的语音对话数据;将所述语音对话数据输入待训练的识别模型,通过所述识别模型的特征提取层,确定所述语音对话数据对应的数据特征;将所述数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的情感强度,作为预测情感强度,以及,将所述数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的情感类别,作为预测情感类别;根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的综合损失值;以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
7.可选地,将所述语音对话数据输入待训练的识别模型,具体包括:针对所述语音对话数据中的每一帧数据,确定该帧数据是否为静音数据;将所述语音对话数据首尾两端的静音数据进行删除处理,得到处理后语音对话数据;将所述处理后语音对话数据输入所述识别模型。
8.可选地,将所述处理后语音对话数据输入所述识别模型,具体包括:
判断所述处理后语音对话数据对应的时间长度是否大于预设时间长度;若是,则对所述处理后语音对话数据进行裁剪,得到裁剪后语音对话数据;将所述裁剪后语音对话数据输入所述识别模型。
9.可选地,根据所述数据特征,将所述数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的情感强度,作为预测情感强度,以及,将所述数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的情感类别,作为预测情感类别,具体包括:根据所述数据特征以及所述语音对话数据对应的时间长度,确定所述语音对话数据对应的平均数据特征;将所述平均数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的所述预测情感强度,以及,将所述平均数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的所述预测情感类别。
10.可选地,根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的综合损失值,具体包括:根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,确定所述识别模型的第一损失值,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的第二损失值;根据所述第一损失值、第一损失值对应的预设权重以及所述第二损失值,确定所述综合损失值。
11.可选地,以最小化所述综合损失值为优化目标,对所述识别模型进行训练,具体包括:根据预设的初始学习率、学习率衰减指数、衰减周期以及训练次数,确定每次对所述识别模型进行训练时,所述识别模型对应的学习率,其中,所述训练次数越多,所述学习率越小;根据每次对所述识别模型进行训练时,所述识别模型对应的学习率,以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
12.本说明书提供了一种业务执行的方法,包括:获取用户的语音数据;将所述语音数据输入预先训练的识别模型,通过所述识别模型的特征提取层,确定所述语音数据对应的语音特征,以及,将所述语音特征输入到所述识别模型的第一分类层,以确定所述语音数据对应的情感强度,以及,将所述语音特征输入到所述识别模型的第二分类层,以确定所述语音数据对应的情感类别,其中,所述识别模型是通过上述模型训练的方法训练得到的;根据所述语音数据对应的情感类别以及所述情感强度,确定业务的执行策略,并根据所述执行策略执行所述业务。
13.本说明书提供了一种模型训练的装置,包括:获取模块,获取用户在历史上执行客服业务的语音对话数据;输入模块,将所述语音对话数据输入待训练的识别模型,通过所述识别模型的特
征提取层,确定所述语音对话数据对应的数据特征;第一确定模块,将所述数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的情感强度,作为预测情感强度,以及,将所述数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的情感类别,作为预测情感类别;第二确定模块,根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的综合损失值;训练模块,以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
14.本说明书提供了一种业务执行的装置,包括:获取模块,获取用户的语音数据;确定模块,将所述语音数据输入预先训练的识别模型,通过所述识别模型的特征提取层,确定所述语音数据对应的语音特征,以及,将所述语音特征输入到所述识别模型的第一分类层,以确定所述语音数据对应的情感强度,以及,将所述语音特征输入到所述识别模型的第二分类层,以确定所述语音数据对应的情感类别,其中,所述识别模型是通过上述模型训练的方法训练得到的;执行模块,根据所述语音数据对应的情感类别以及所述情感强度,确定业务的执行策略,并根据所述执行策略执行所述业务。
15.本说明书采用的上述至少一个技术方案能够达到以下有益效果:在本说明书提供的模型训练的方法中,本说明书公开了一种模型训练和业务执行的方法、装置、介质及设备。该模型训练的方法包括:获取用户在历史上执行客服业务的语音对话数据并输入待训练的识别模型,通过识别模型的特征提取层,确定语音对话数据对应的数据特征,以及确定所述语音对话数据对应的情感强度,作为预测情感强度,和语音对话数据对应的情感类别,作为预测情感类别,根据预测情感强度和语音对话数据对应的实际情感强度之间的偏差,以及预测情感类别和语音对话数据对应的实际情感类别之间的偏差,确定识别模型的综合损失值,以最小化该综合损失值为优化目标,对识别模型进行训练。
16.从上述方法可以看出,本方案在识别模型的训练过程中,能够根据语音数据的预测情感类别和实际情感类别之间的偏差,以及语音数据的预测情感强度和实际情感强度之间的偏差,确定出识别模型的综合损失函数,这样一来,就能够使模型同时识别出语音数据的情感类别和情感轻度两种相互关联的识别结果,使得识别结果更加丰富、准确,从而能够根据这两种识别结果确定出准确的业务策略以执行业务。
附图说明
17.此处所说明的附图用来提供对本说明书的进一步理解,构成本说明书的一部分,本说明书的示意性实施例及其说明用于解释本说明书,并不构成对本说明书的不当限定。在附图中:图1为本说明书中提供的一种模型训练的方法的流程示意图;图2为本说明书中提供的一种业务执行的方法的流程示意图;图3为本说明书中提供的一种识别模型的识别过程示意图;
图4为本说明书中提供的一种模型训练的装置示意图;图5为本说明书中提供的一种业务执行的装置示意图;图6为本说明书提供的一种对应于图1的电子设备示意图。
具体实施方式
18.为使本说明书的目的、技术方案和优点更加清楚,下面将结合本说明书具体实施例及相应的附图对本说明书技术方案进行清楚、完整地描述。显然,所描述的实施例仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本说明书保护的范围。
19.以下结合附图,详细说明本说明书各实施例提供的技术方案。
20.图1为本说明书中提供的一种模型训练的方法的流程示意图,包括以下步骤:s101:获取用户在历史上执行客服业务的语音对话数据。
21.在人机交互的场景下,诸如智能客服、智能对话机器人等服务端通常会对采集到的用户语音对话进行识别,进而根据识别结果来执行相应的交互动作,如对用户的对话进行语音、文字等回复,向用户展示相应的信息以及与用户进行动作互动等。
22.而以往的研究表明,语音情感强度在情感表达中起着重要的作用,语音的情感强度(情感的强烈程度)与情感类别(如愤怒、兴奋、快乐、悲伤等)之间存在一定的关系,高情感强度的语音片段往往会包含有很多负面情感,如愤怒、恐惧、悲伤和厌恶等,在高情感强度的语音中最常见,低唤醒水平的情感(如无聊、冷漠等),在低情感强度的语音片段中最常见,而幸福感在中等情感强度的语音片段中最为普遍。
23.而目前在进行情感识别的过程中,忽略了情感强度这一信息在情感表达中所起到的作用,导致仅根据识别到情感类型类执行下游业务(如执行相应的交互动作)时准确性较低,不能很好的保证用户体验。而其中识别模型的结构以及训练方式决定了最终得到的识别结果。
24.基于此,本说明书提供了一种模型训练的方法,其中,需要获取语音对话数据。服务器可以从诸如交互式情感二元动作捕捉数据库(interactive emotional dyadic motion capture database,iemocap)等开源语意数据集中获取到语音对话数据。当然,也可以从相应的网站、应用客户端等其他渠道获取语音对话数据,本说明书对此不做具体限定。
25.另外,在对识别模型进行训练的过程中,服务器可以按照会话对数据库中的语音对话数据以及测试数据进行划分,如当数据库中包含有五个会话对应的语音数据时,则可以将其中四个会话对应的语音数据作为训练数据,将剩余的一个会话对应的语音数据作为测试数据。
26.针对其中的每个语音对话数据,该语音对话数据中可以标注有情感强度以及情感类别两种标签,情感强度表征情感的强烈程度,在上述iemocap数据库中,共包含有9种激活程度(arousal)的标签,由低到高的9种激活程度分别对应由弱到强的9 种情感强度。在本说明书中,考虑到有些情感强度的样本数量较少,因此,可以将这9种情感强度进行重新划分,如分为强、中、若3类,或者强、弱2类。
27.此外,上述情感类型可以包括中性、快乐、愤怒、悲伤等,对于其中一些样本数量较
少的情感类型,可以将其与其他情感类型进行合并,如语音对话数据中情感类型的标签还包含有“兴奋”这一情感类型,但是考虑到该情感类型的样本数量较少,可以将其归类至快乐这一情感类型中。当然,在本说明书中还可以包含有其他情感类型,以上仅是以几种有代表性的情感类型进行说明,对于其他的情感类型在此处不做过多赘述。
28.在本说明书中,用于模型训练和业务执行的方法的执行主体,可以指服务器等设置于业务平台的指定设备,为了便于描述,本说明书仅以服务器是执行主体为例,对本说明书提供的一种模型训练和业务执行的方法进行说明。
29.s102:将所述语音对话数据输入待训练的识别模型,通过所述识别模型的特征提取层,确定所述语音对话数据对应的数据特征。
30.服务器将语音对话数据输入待识别模型之前,可以先对该语音对话数据进行处理,具体的,服务器可以先对各语音对话数据进行静音检测,针对每个语音对话数据,服务器可以针对语音对话数据中的每一帧数据,确定该帧数据是否为静音数据,而后将语音对话数据首尾两端的静音数据进行删除处理,得到处理后语音对话数据,例如,针对其中一个语音对话数据,该语音对话数据共有300帧,若前50帧和后60帧对应的数据为静音数据,则可以将前50帧和后60帧的数据进行删除,从而知保留中间190帧的数据。当然,服务器也可以将语音对话数据中所有的静音数据进行删除处理,从而只保留非静音的数据。
31.在本说明书中,判断是否为静音数据的依据可以由识别模型的实际应用场景进行决定,当该识别模型应用于人机交互的场景时,判断每帧数据是否为静音数据的依据可以为是否包含有人类语音,即将不包含有人类语音的数据作为静音数据。在本说明书中,也可以通过相应的深度学习模型来对语音对话数据中的静音数据进行判断及识别。
32.进一步的,为了防止输入识别模型中的语音对话数据占用过多的系统资源(如内存),可以将上述处理后的语音数据裁剪至预设的时间范围内,服务器可以判断各语音对话数据是否大于预设时间长度。若是,则裁剪掉大于预设时间长度的语音,并将裁剪后的语音对话数据输入识别模型,而若语音对话数据小于预设时间长度,则可以将其直接输入到识别模型中。其中,上述预设时间长度可以根据实际情况进行设定,本说明书对此不做具体限定。
33.例如,若其中一个语音对话数据的时间长度为8s,而预设时间长度为6s,则可以将该语音对话数据最后2s的数据进行删除,从而只保留前6s的语音数据。
34.将上述裁剪后语音对话数据输入识别模型后,服务器可以通过该识别模型的特征提取层,确定语音对话数据对应的数据特征。其中,该识别模型的特征提取层可以设置有7层卷积神经网络(convolutional neural network,cnn),各层cnn的步长可以分别为5,2,2,2,2,2,2,各层cnn卷积核宽度可以分别为10,3,3,3,3,2,2,输出通道(channels)大小可以设置为512。对于1s长度的语音,对应输入的矩阵大小可以设置为(1,16000),则对应的输出为(512,50),即输出50个512维的向量,相当于每20ms产生一个512维的特征向量。
35.s103:将所述数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的情感强度,作为预测情感强度,以及,将所述数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的情感类别,作为预测情感类别。
36.服务器获取到语音对话数据对应的数据特征后,可以进一步采用全局平均池化的方法在时间维度上将数据特征的长度进行统一,如将提取到的数据特征长度统一为768。这
为预测情感类别,为语音对话数据对应的实际情感类别(即语音对话数据的实际情感类别标签),在计算过程中,可以为情感类别标签对应的one hot编码向量。
45.而后服务器可以根据确定出的第一损失值、第一损失值对应的权重以及第二损失值确定出识别模型的综合损失值。其中,由于在根据识别结果执行事务的过程中,识别的到情感强度相对于情感类型对事务的影像较小,因此,会对第一损失值设置一定的权重,经过大量实验表明,当第一损失值对应的权重为0.5时,语音识别的效果较高,因此,在本说明书中可以将第一损失值对应的权重设置为0.5,当然,也可以设置为其他值,本说明书对此不做具体限定。该综合损失值的计算公式可以为:其中,为识别模型对应的综合损失值,为第一损失值对应的权重。
46.s105:以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
47.确定综合损失值后,服务器可以以最小化该综合损失值为优化目标,对识别模型进行训练,直至该识别模型收敛至预设范围内,或者达到预设训练次数,方可将其部署在业务平台,从而根据该识别模型的识别结果执行下游的事务。
48.具体的,在模型训练的过程中可以通过自适应矩估计(adaptive moments estimation,adam)优化器,采用随训练步数指数递减的学习率来对模型参数进行更新,根据预设的初始学习率、学习率衰减指数、衰减周期以及训练次数,确定每次对识别模型进行训练时,识别模型对应的学习率,其中,训练次数越多,所述学习率越小,从而使学习率随着训练步数的增加而指数程度的衰减。
49.该学习率可以通过如下公式进行计算:其中,为学习率,为识别模型的初始学习率,为学习率的衰减指数, 为当前训练次数,为衰减周期。
50.其中,在本说明书中,可以预先对模型训练中的超参数进行设置,在每一批次对模型进行训练时,语音对话数据量可以为64,初始学习率可以设置为0.0001,学习率的衰减指数可以设置为0.98,最大的批次可以设置为50,训练精度可以设置为32。
51.以上为对本说明书提供的一种模型训练的方法进行的说明,下面将在经过上述模型训练的方法得到的识别模型的实际应用角度,对本说明书提供的一种业务执行的方法进行说明,如图2所示。
52.图2为本说明书中提供的一种业务执行的方法示意图,包括以下步骤:s201:获取用户的语音数据。
53.s202:将所述语音数据输入预先训练的识别模型,通过所述识别模型的特征提取层,确定所述语音数据对应的语音特征,以及,将所述语音特征输入到所述识别模型的第一分类层,以确定所述语音数据对应的情感强度,以及,将所述语音特征输入到所述识别模型的第二分类层,以确定所述语音数据对应的情感类别,其中,所述识别模型是通过上述模型训练的方法训练得到的。
54.服务器可以通过传感器采集到的或者用户在相应的客户端中输入的语音数据,进
而将该语音数据输入之前训练并部署的识别模型,通过识别模型的特征提取层,确定语音数据对应的语音特征,并将语音特征输入到识别模型的第一分类层,以确定所述语音数据对应的情感强度,以及,将语音特征输入到识别模型的第二分类层,以确定语音数据对应的情感类别。为了便于理解,本说明书还提供了一种识别模型的识别过程示意图,如图3所示。
55.图3为本说明书中提供的一种识别模型的识别过程示意图。
56.其中,当识别模型获取到用户的语音数据后,可以将该语音数据输入识别模型的特征提取网络,通过该特征提取网络的多个卷积层(cnn)以及转换网络transformer network的处理,得到语音特征,进而通过池化层对该语音数据进行平均池化处理,得到平均数据特征。而后可以将该平均数据特征分别输入第二分类层以及第一分类层,以分别确定语音数据对应的情感类别和情感强度。
57.s203:根据所述语音数据对应的情感类别以及所述情感强度,确定业务的执行策略,并根据所述执行策略执行所述业务。
58.而后服务器可以根据得到的情感类别和情感强度,确定业务的执行策略,例如,服务器可以根据用户的语音数据所表达出来的情感类别和情感强度,确定用户当前所表达的情绪,进而根据用户当前用户所表达的情绪,确定业务的执行策略,如确定需要向用户恢复的语音或者文字内容,或是控制智能机器人展示相应的交互动作等,从而执行相应的业务。
59.从上述方法可以看出,本方案在识别模型的训练过程中,能够根据语音数据的预测情感类别和实际情感类别之间的偏差,以及语音数据的预测情感强度和实际情感强度之间的偏差,确定出识别模型的综合损失函数,这样一来,就能够使模型同时识别出语音数据的情感类别和情感轻度两种相互关联的识别结果,使得识别结果更加丰富、准确,从而能够根据这两种识别结果确定出准确的业务策略以执行业务。
60.另外,本方案通过对情感强度识别和情感类别识别这两种分类任务的损失函数的计算,确定出最终的综合损失函数,使得通过多任务学习后的识别模型所识别出的情感类别和情感强度之间具有较强的关联性,这样一来,无论是确定出的情感类别,还是确定出的情感强度都更加准确。
61.以上为本说明书的一个或多个实施模型训练和业务执行的方法,基于同样的思路,本说明书还提供了相应的模型训练和业务执行的装置,如图4或图5所示。
62.图4为本说明书提供的一种模型训练的装置示意图,包括:获取模块401,用于获取用户在历史上执行客服业务的语音对话数据;输入模块402,用于将所述语音对话数据输入待训练的识别模型,通过所述识别模型的特征提取层,确定所述语音对话数据对应的数据特征;第一确定模块403,用于将所述数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的情感强度,作为预测情感强度,以及,将所述数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的情感类别,作为预测情感类别;第二确定模块404,用于根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的综合损失值;训练模块405,用于以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
63.可选地,所述输入模块402具体用于,针对所述语音对话数据中的每一帧数据,确定该帧数据是否为静音数据;将所述语音对话数据首尾两端的静音数据进行删除处理,得到处理后语音对话数据;将所述处理后语音对话数据输入所述识别模型。
64.可选地,所述输入模块402具体用于,判断所述处理后语音对话数据对应的时间长度是否大于预设时间长度;若是,则对所述处理后语音对话数据进行裁剪,得到裁剪后语音对话数据;将所述裁剪后语音对话数据输入所述识别模型。
65.可选地,所述第一确定模块403具体用于,根据所述数据特征以及所述语音对话数据对应的时间长度,确定所述语音对话数据对应的平均数据特征;将所述平均数据特征输入到所述识别模型的第一分类层,以确定所述语音对话数据对应的所述预测情感强度,以及,将所述平均数据特征输入到所述识别模型的第二分类层,以确定所述语音对话数据对应的所述预测情感类别。
66.可选地,所述第二确定模快404具体用于,根据所述预测情感强度和所述语音对话数据对应的实际情感强度之间的偏差,确定所述识别模型的第一损失值,以及所述预测情感类别和所述语音对话数据对应的实际情感类别之间的偏差,确定所述识别模型的第二损失值;根据所述第一损失值、第一损失值对应的预设权重以及所述第二损失值,确定所述综合损失值。
67.可选地,所述训练模块405具体用于,根据预设的初始学习率、学习率衰减指数、衰减周期以及训练次数,确定每次对所述识别模型进行训练时,所述识别模型对应的学习率,其中,所述训练次数越多,所述学习率越小;根据每次对所述识别模型进行训练时,所述识别模型对应的学习率,以最小化所述综合损失值为优化目标,对所述识别模型进行训练。
68.图5为本说明书提供的一种业务执行的装置示意图,包括:获取模块501,用于获取用户的语音数据;确定模块502,用于将所述语音数据输入预先训练的识别模型,通过所述识别模型的特征提取层,确定所述语音数据对应的语音特征,以及,将所述语音特征输入到所述识别模型的第一分类层,以确定所述语音数据对应的情感强度,以及,将所述语音特征输入到所述识别模型的第二分类层,以确定所述语音数据对应的情感类别,其中,所述识别模型是通过上述模型训练的装置训练得到的;执行模块503,用于根据所述语音数据对应的情感类别以及所述情感强度,确定业务的执行策略,并根据所述执行策略执行所述业务。
69.本说明书还提供了一种计算机可读存储介质,该存储介质存储有计算机程序,计算机程序可用于执行上述图1或图2提供的一种模型训练和业务执行的方法。
70.本说明书还提供了图6所示的一种对应于图1或图2的电子设备的示意结构图。如图6所述,在硬件层面,该电子设备包括处理器、内部总线、网络接口、内存以及非易失性存储器,当然还可能包括其他业务所需要的硬件。处理器从非易失性存储器中读取对应的计算机程序到内存中然后运行,以实现上述图1或图2所述的模型训练和业务执行的方法。当然,除了软件实现方式之外,本说明书并不排除其他实现方式,比如逻辑器件抑或软硬件结合的方式等等,也就是说以下处理流程的执行主体并不限定于各个逻辑单元,也可以是硬件或逻辑器件。
71.在20世纪90年代,对于一个技术的改进可以很明显地区分是硬件上的改进(例如,
对二极管、晶体管、开关等电路结构的改进)还是软件上的改进(对于方法流程的改进)。然而,随着技术的发展,当今的很多方法流程的改进已经可以视为硬件电路结构的直接改进。设计人员几乎都通过将改进的方法流程编程到硬件电路中来得到相应的硬件电路结构。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(programmable logic device, pld)(例如现场可编程门阵列(field programmable gate array,fpga))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片pld上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今,取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compiler)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(hardware description language,hdl),而hdl也并非仅有一种,而是有许多种,如abel(advanced boolean expression language)、ahdl(altera hardware description language)、confluence、cupl(cornell university programming language)、hdcal、jhdl(java hardware description language)、lava、lola、myhdl、palasm、rhdl(ruby hardware description language)等,目前最普遍使用的是vhdl(very-high-speed integrated circuit hardware description language)与verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
72.控制器可以按任何适当的方式实现,例如,控制器可以采取例如微处理器或处理器以及存储可由该(微)处理器执行的计算机可读程序代码(例如软件或固件)的计算机可读介质、逻辑门、开关、专用集成电路(application specific integrated circuit,asic)、可编程逻辑控制器和嵌入微控制器的形式,控制器的例子包括但不限于以下微控制器:arc 625d、atmel at91sam、microchip pic18f26k20 以及silicone labs c8051f320,存储器控制器还可以被实现为存储器的控制逻辑的一部分。本领域技术人员也知道,除了以纯计算机可读程序代码方式实现控制器以外,完全可以通过将方法步骤进行逻辑编程来使得控制器以逻辑门、开关、专用集成电路、可编程逻辑控制器和嵌入微控制器等的形式来实现相同功能。因此这种控制器可以被认为是一种硬件部件,而对其内包括的用于实现各种功能的装置也可以视为硬件部件内的结构。或者甚至,可以将用于实现各种功能的装置视为既可以是实现方法的软件模块又可以是硬件部件内的结构。
73.上述实施例阐明的系统、装置、模块或单元,具体可以由计算机芯片或实体实现,或者由具有某种功能的产品来实现。一种典型的实现设备为计算机。具体的,计算机例如可以为个人计算机、膝上型计算机、蜂窝电话、相机电话、智能电话、个人数字助理、媒体播放器、导航设备、电子邮件设备、游戏控制台、平板计算机、可穿戴设备或者这些设备中的任何设备的组合。
74.为了描述的方便,描述以上装置时以功能分为各种单元分别描述。当然,在实施本说明书时可以把各单元的功能在同一个或多个软件和/或硬件中实现。
75.本领域内的技术人员应明白,本说明书的实施例可提供为方法、系统、或计算机程序产品。因此,本说明书可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本说明书可采用在一个或多个其中包含有计算机可用程序代码的
计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。
76.本说明书是参照根据本说明书实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
77.这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
78.这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
79.在一个典型的配置中,计算设备包括一个或多个处理器(cpu)、输入/输出接口、网络接口和内存。
80.内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(ram)和/或非易失性内存等形式,如只读存储器(rom)或闪存(flash ram)。内存是计算机可读介质的示例。
81.计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(pram)、静态随机存取存储器(sram)、动态随机存取存储器(dram)、其他类型的随机存取存储器(ram)、只读存储器(rom)、电可擦除可编程只读存储器(eeprom)、快闪记忆体或其他内存技术、只读光盘只读存储器(cd-rom)、数字多功能光盘(dvd)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
82.还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个
……”
限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
83.本领域技术人员应明白,本说明书的实施例可提供为方法、系统或计算机程序产品。因此,本说明书可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本说明书可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产
品的形式。
84.本说明书可以在由计算机执行的计算机可执行指令的一般上下文中描述,例如程序模块。一般地,程序模块包括执行特定任务或实现特定抽象数据类型的例程、程序、对象、组件、数据结构等等。也可以在分布式计算环境中实践本说明书,在这些分布式计算环境中,由通过通信网络而被连接的远程处理设备来执行任务。在分布式计算环境中,程序模块可以位于包括存储设备在内的本地和远程计算机存储介质中。
85.本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于系统实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
86.以上所述仅为本说明书的实施例而已,并不用于限制本说明书。对于本领域技术人员来说,本说明书可以有各种更改和变化。凡在本说明书的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本说明书的权利要求范围之内。
再多了解一些

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

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

相关文献