CN112114874B - 数据处理方法、装置、电子设备和存储介质 - Google Patents
数据处理方法、装置、电子设备和存储介质 Download PDFInfo
- Publication number
- CN112114874B CN112114874B CN202010844165.2A CN202010844165A CN112114874B CN 112114874 B CN112114874 B CN 112114874B CN 202010844165 A CN202010844165 A CN 202010844165A CN 112114874 B CN112114874 B CN 112114874B
- Authority
- CN
- China
- Prior art keywords
- bit
- model data
- bits
- instruction
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/30003—Arrangements for executing specific machine instructions
- G06F9/30007—Arrangements for executing specific machine instructions to perform operations on data operands
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N3/00—Computing arrangements based on biological models
- G06N3/02—Neural networks
- G06N3/06—Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons
- G06N3/063—Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons using electronic means
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- General Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- Health & Medical Sciences (AREA)
- Life Sciences & Earth Sciences (AREA)
- Biomedical Technology (AREA)
- Biophysics (AREA)
- Data Mining & Analysis (AREA)
- General Health & Medical Sciences (AREA)
- Molecular Biology (AREA)
- Computing Systems (AREA)
- Evolutionary Computation (AREA)
- Computational Linguistics (AREA)
- Mathematical Physics (AREA)
- Artificial Intelligence (AREA)
- Neurology (AREA)
- Information Transfer Between Computers (AREA)
- Executing Machine-Instructions (AREA)
Abstract
本申请公开了一种数据处理方法、装置、电子设备和存储介质,涉及语音交互技术、自动驾驶、智能家居以及深度学习技术领域。具体实现方案为:获取待处理的16比特的模型数据;获取4比特加载指令;根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。由此,本申请能够通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,从而提高了低比特模型数据处理效率,有效地降低了网络通信成本所导致的顺序访问吞吐无法提高和突破的问题。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
Description
技术领域
本申请的实施例总体上涉及数据处理技术领域,并且更具体地涉及语音交互技术、自动驾驶、智能家居以及深度学习技术领域。
背景技术
在语音交互领域中,部分采用Cadence高保真(HiFi)4基本架构的芯片,在进行神经网络的运算的过程中,能够兼备实时处理功能,支持多路麦克阵列语音信号输入,已逐渐成为了最受青睐的芯片之一。针对车载语音交互、智能家居等多种涉及语音交互技术的应用场景下,通常会使用配置有前述芯片的数据处理装置对用户输入的模型数据进行处理,并对车辆、智能家电等进行控制。然而由于芯片对模型波束算法的支持局限性极大,势必会导致数据处理效率极低。
现有技术中,通常采用对信号处理进行优化等方式来提高数据处理效率。然而,优化信号处理等方式并不适合深度学习。即言,提高数据处理效率的方案尚不完善。因此,如何提高数据处理效率,已成为了重要的研究方向之一。
发明内容
本申请提供了一种数据处理方法、装置、电子设备和存储介质。
根据第一方面,提供了一种数据处理方法,应用于数据处理装置中,所述数据处理装置包括高保真4架构,包括:
获取待处理的16比特的模型数据;
获取4比特加载指令;
根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
根据第二方面,提供了一种数据处理装置,包括:
第一获取模块,用于获取待处理的16比特的模型数据;
第二获取模块,用于获取4比特加载指令;
第一加载模块,用于根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
根据第三方面,提供了一种电子设备,包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行本申请第一方面所述的数据处理方法。
根据第四方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,所述计算机指令用于使所述计算机执行本申请第一方面所述的数据处理方法。
根据第五方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据本申请第一方面所述的数据处理方法。
本申请提供的实施例,至少具有如下有益技术效果:
根据本申请实施例的数据处理方法,可以通过获取待处理的16比特的模型数据以及4比特加载指令,然后根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现低比特模型数据的处理。由此,本申请能够通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,从而提高了低比特模型数据处理效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨互联网数据中心(InternetData Center,简称IDC)以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
应当理解,本部分所描述的内容并非旨在标识本申请的实施例的关键或重要特征,也不用于限制本申请的范围。本申请的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本申请的限定。其中:
图1是根据本申请第一实施例的示意图;
图2是根据本申请第二实施例的示意图;
图3是根据本申请第三实施例的示意图;
图4是根据本申请第四实施例的示意图;
图5是用来实现本申请实施例的数据处理方法的数据处理装置的框图;
图6是用来实现本申请实施例的数据处理方法的处理电子设备的框图。
具体实施方式
以下结合附图对本申请的示范性实施例做出说明,其中包括本申请实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本申请的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
下面参考附图描述本申请实施例的数据处理方法、装置、电子设备和存储介质。
图1是根据本申请第一实施例的示意图。其中,需要说明的是,本实施例的数据处理方法的执行主体为数据处理装置,数据处理装置具体可以为硬件设备,或者硬件设备中的软件等。其中,硬件设备例如终端设备、服务器等。如图1所示,本实施例提出的数据处理方法,包括如下步骤:
S101、获取待处理的16比特的模型数据。
本申请实施例中,可以对车载语音交互、智能家居等场景中,用户输入的16比特的模型数据进行处理。
可选地,用户可以利用控制终端(如遥控器、手机应用程序(Application,简称APP)等)输入16比特的模型数据,以下发相应的控制指令,例如,开机、切换运行模式等。相应地,当用户输入16比特的模型数据后,可以获取该待处理的16比特的模型数据,以对该模型数据进行处理。
其中,模型数据,指的是用户于多种场景下输入的数据。例如,模型数据可以为用户在与对应家用电器进行语音交互时输入的数据;又例如,模型数据可以为司乘人员在与车载电脑进行语音交互时输入的数据。
S102、获取4比特加载指令。
需要说明的是,现有数据处理方法中,在通过高保真(HiFi)4架构对模型数据进行人工神经网络(Artificial Neural Network,简称ANN),简称神经网络(Neural Network,简称NN)或者连接模型(Connection Model)运算时,可以于加载过程中加载4个8比特到64比特的寄存器中。也就是说,在HiFi 4的运算过程中,可以将8比特的模型数据加载为16比特的高8位,然后进行16比特的运算。其中,硬件中有4个16x16的单路乘法器。在实际应用中,可以混用4个16x16的乘法器,以将其作为8个8x8的乘法器使用,能够实现双倍计算效率。
其中,神经网络是一种模仿生物神经网络(动物的中枢神经系统,特别是大脑)的行为特征,进行分布式并行信息处理的算法数学模型。神经网络依靠系统的复杂程度,通过调整内部大量节点之间相互连接的关系,从而达到处理信息的目的。
然而,现有HiFi 4架构并不支持低比特,例如4比特的加载,通常需要使用8比特加载,将加载的数据掩膜(Mask)至4比特,然后进行移位及乘法操作。这样一来,势必导致运算效率的大幅度降低。
本申请实施例中,在原有HiFi 4架构的基础上,通过添加4比特加载指令,以在获取到待处理的16比特的模型数据后,可以获取4比特加载指令,以实现4比特的加载,从而提高低比特运算效率。
S103、根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
本申请实施例中,可以根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
需要说明的是,语音的神经网络中存在大量的长短期记忆网络(Long ShortTermMemory,简称LSTM)、门控循环单位网络(Gated Recurrent Unit,简称GRU)、网状信道网络(Fibre Channel,简称FC)等网络,前述网络以全连接层为基础,配合各种激活函数构造神经网络。针对多种芯片,例如为了低功耗处理而不能外接双倍数据率同步动态随机存取存储器(Double Data Rate Synchronous Dynamic Random Access Memory,简称DDR SDRAM)的芯片,其存储内存势必会严重受限。这样一来,低比特对于较小的内存来说是非常重要的,加载低比特可以使全连接层压缩至原来的一半,以在不增加芯片面积的情况下,充分利用芯片的内存空间,使芯片可以存放更大的神经网络,从而最大效率发挥芯片对模型波束算法的支持。
根据本申请实施例的数据处理方法,可以通过获取待处理的16比特的模型数据以及4比特加载指令,然后根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现低比特模型数据的处理。由此,本申请能够通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,从而提高了低比特模型数据处理效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
需要说明的是,本申请中,为了进一步提升数据处理效率,还可以添加4比特加载为8比特的加载指令、4比特运算指令以及1比特点积运算指令。
下面分别针对上述指令进行解释说明。
针对4比特加载为8比特的加载指令,作为一种可能的实现方式,如图2所示,在上述实施例的基础上,添加4比特加载为8比特的加载指令的处理过程,具体包括以下步骤:
S201、获取4比特加载为8比特的加载指令。
本申请实施例中,在原有HiFi 4架构的基础上,通过添加4比特加载为8比特的加载指令,以根据该加载指令实现4比特加载为8比特的运算方式。
S202、根据4比特加载为8比特的加载指令,将4比特的模型数据从寄存器中加载到8*8乘法器的高4位。
本申请实施例中,在获取到4比特加载为8比特的加载指令后,可以根据4比特加载为8比特的加载指令,将4比特的模型数据从寄存器中加载到8*8乘法器的高4位。也就是说,在HiFi 4的运算过程中,可以将4比特的模型数据从寄存器中加载到8*8乘法器的高4位,然后进行8比特的运算。
根据本申请实施例的数据处理方法,可以通过添加4比特加载为8比特的加载指令,使得在数据的处理过程中,能够实现双倍的8*4比特的双倍性能的运算效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
针对4比特运算指令,作为一种可能的实现方式,如图3所示,在上述实施例的基础上,添加获取4比特运算指令的处理过程,具体包括以下步骤:
S301、获取4比特运算指令。
本申请实施例中,在原有HiFi 4架构的基础上,通过添加4比特运算指令,以根据该运算指令实现4比特的运算。
S302、根据4比特运算指令对8*8乘法器中位于高4位的4比特的模型数据进行4比特的点积运算。
本申请实施例中,在获取到4比特运算指令后,可以根据4比特运算指令对8*8乘法器中位于高4位的4比特的模型数据进行4比特的点积运算,以根据该运算指令添加8*8的运算单元,将点积运算从16*16比特切换至8*8比特,从而借用16*16比特的运算单元,可实现最多4个8*8比特的运算。
根据本申请实施例的数据处理方法,可以通过添加4比特运算指令,使得在数据的处理过程中,能够实现双倍的8*8比特的运算效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
针对1比特点积运算指令,作为一种可能的实现方式,如图4所示,在上述实施例的基础上,添加1比特点积运算指令的处理过程,具体包括以下步骤:
S401、获取1比特点积运算指令。
本申请实施例中,在原有HiFi 4架构的基础上,通过添加1比特点积运算指令,以根据该运算指令实现1比特的运算。
S402、根据1比特点积运算指令对两个1比特的输入数据和模型数据进行异或运算。
本申请实施例中,在获取到1比特点积运算指令后,可以根据1比特点积运算指令对两个1比特的输入数据和模型数据进行异或(Exclusive OR,简称X OR)运算,以获取1比特的矩阵操作。其中,在试图对两个1比特数据进行异或运算时,源操作数为两个,分别为输入量化为1比特的输入数据和模型数据的1比特值。
其中,试图通过异或运算计算1比特的矩阵操作的具体运算方式为现有技术,此处不再赘述。
S403、计算异或运算结果中1的个数。
S404、将1的个数确定为两个1比特的输入数据和模型数据点积运算的结果。
本申请实施例中,在根据1比特点积运算指令对两个1比特的模型数据进行异或运算后,可以计算异或运算结果中1的个数,然后将1的个数确定为1比特的模型数据点积(DotProduct)运算的结果。
举例而言,获取到的异或运算结果为0、1、1、1、0、1,可知,异或运算结果中1的个数为4,则可以将4确定为1比特的模型数据点积运算的结果。
根据本申请实施例的数据处理方法,可以通过添加1比特点积运算指令,使得在数据的处理过程中,能够基于相当于乘法的异或运算以及相当于加法的异或运算结果中1的个数的计算,实现快速获取1比特的数据点积运算的结果,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
综上所述,本申请通过添加4比特加载指令、4比特加载为8比特的加载指令、4比特运算指令以及1比特点积运算指令等指令,使得包括HiFi 4架构的数据处理装置能够在处理8*4比特的神经网络运算的时候,处理效率得到8倍左右的提升,并有效地降低了网络通信成本所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率,相较于现有的顺序访问,吞吐量提高了2~3倍。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
需要说明的是,本申请提出的数据处理方法,可以运用于多种涉及语音交互技术的场景中。
针对车载语音交互应用场景,可以获取用户输入的“刹车”、“减速”等16比特的语音,并通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现数据的精准识别。由此,通过于HiFi 4中添加4比特加载指令,能够提高了低比特模型数据处理效率,避免误识别,从而确保了车辆行驶过程中的安全性。
针对智能家电应用场景,可以获取用户输入的“室内PM2.5指数正常吗”、“请开启除湿功能”等16比特的语音,并通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现数据的精准识别。由此,通过于HiFi 4中添加4比特加载指令,能够提高了低比特模型数据处理效率,确保在嘈杂环境中用户输入数据的精准识别,从而提高了智能家电控制过程中的有效性,提升了用户体验。
与上述几种实施例提供的数据处理方法相对应,本申请的一个实施例还提供一种数据处理装置,由于本申请实施例提供的数据处理装置与上述几种实施例提供的数据处理方法相对应,因此在数据处理方法的实施方式也适用于本实施例提供的数据处理装置,在本实施例中不再详细描述。图5是根据本申请一个实施例的数据处理装置的结构示意图。
如图5所示,该数据处理装置2000,包括:第一获取模块111、第二获取模块112和第一加载模块113。其中:
第一获取模块111,用于获取待处理的16比特的模型数据;
第二获取模块112,用于获取4比特加载指令;
第一加载模块112,用于根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
在本申请的实施例中,如图5所示,数据处理装置2000,还包括:第三获取模块114,用于获取4比特加载为8比特的加载指令;第二加载模块115,用于根据所述4比特加载为8比特的加载指令,将所述4比特的模型数据从所述寄存器中加载到8*8乘法器的高4位。
在本申请的实施例中,如图5所示,模型数据处理装置2000,还包括:第四获取模块116,用于获取4比特运算指令;第三加载模块117,用于根据所述4比特运算指令对所述8*8乘法器中位于高4位的所述4比特的模型数据进行4比特的点积运算。
在本申请的实施例中,如图5所示,模型数据处理装置2000,还包括:第五获取模块118,用于获取1比特点积运算指令;异或运算模块119,用于根据1比特点积运算指令对两个1比特的输入数据和模型数据进行异或运算;个数计算模块120,用于计算异或运算结果中1的个数;确定模块121,用于将所述1的个数确定为所述两个1比特的输入数据和模型数据点积运算的结果。
根据本申请实施例的数据处理装置,可以通过获取待处理的16比特的模型数据以及4比特加载指令,然后根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现低比特模型数据的处理。由此,本申请能够通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,从而提高了低比特模型数据处理效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
根据本申请的实施例,本申请还提供了一种电子设备和一种可读存储介质。
如图6所示,是根据本申请实施例的数据处理方法的电子设备的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本申请的实现。
如图6所示,该电子设备包括:一个或多个处理器1100、存储器1200,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在电子设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在其它实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个电子设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图6中以一个处理器1100为例。
存储器1200即为本申请所提供的非瞬时计算机可读存储介质。其中,所述存储器存储有可由至少一个处理器执行的指令,以使所述至少一个处理器执行本申请所提供的数据处理方法。本申请的非瞬时计算机可读存储介质存储计算机指令,该计算机指令用于使计算机执行本申请所提供的数据处理方法。
存储器1200作为一种非瞬时计算机可读存储介质,可用于存储非瞬时软件程序、非瞬时计算机可执行程序以及模块,如本申请实施例中的数据处理方法对应的程序指令/模块(例如,附图5所示的第一获取模块111、第二获取模块112和第一加载模块113)。处理器1100通过运行存储在存储器1200中的非瞬时软件程序、指令以及模块,从而执行服务器的各种功能应用以及数据处理,即实现上述方法实施例中的数据处理方法。
存储器1200可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据处理电子设备的使用所创建的数据等。此外,存储器1200可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些实施例中,存储器1200可选包括相对于处理器1100远程设置的存储器,这些远程存储器可以通过网络连接至处理电子设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
数据处理方法的电子设备还可以包括:输入装置1300和输出装置1400。处理器1100、存储器1200、输入装置1300和输出装置1400可以通过总线或者其他方式连接,图6中以通过总线连接为例。
输入装置1300可接收输入的数字或字符信息,以及产生与处理电子设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等输入装置。输出装置1400可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。该显示设备可以包括但不限于,液晶显示器(LCD)、发光二极管(LED)显示器和等离子体显示器。在一些实施方式中,显示设备可以是触摸屏。
此处描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、专用ASIC(专用集成电路)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
这些计算程序(也称作程序、软件、软件应用、或者代码)包括可编程处理器的机器指令,并且可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。如本文使用的,术语“机器可读介质”和“计算机可读介质”指的是用于将机器指令和/或数据提供给可编程处理器的任何计算机程序产品、设备、和/或装置(例如,磁盘、光盘、存储器、可编程逻辑装置(PLD)),包括,接收作为机器可读信号的机器指令的机器可读介质。术语“机器可读信号”指的是用于将机器指令和/或数据提供给可编程处理器的任何信号。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)、互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务("Virtual Private Server",或简称"VPS")中,存在的管理难度大,业务扩展性弱的缺陷。
本申请还提供一种计算机程序产品,当所述计算机程序产品中的指令处理器执行时,实现如上所述的数据处理方法。
根据本申请实施例的数据处理方法,可以通过获取待处理的16比特的模型数据以及4比特加载指令,然后根据4比特加载指令从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,以实现低比特模型数据的处理。由此,本申请能够通过添加4比特加载指令,从16比特的模型数据中加载4个4比特的模型数据到64位寄存器中,从而提高了低比特模型数据处理效率,有效地降低了网络通信成本(延时和故障)所导致的顺序访问吞吐无法提高和突破的问题,从而使整个系统的顺序访问吞吐不受跨IDC以及网络拓扑的影响,大大提高了系统对资源的利用率及吞吐量。进一步地,通过添加自定义指令,能够在不增加芯片面积的情况下,使芯片可以存放更大的神经网络,实现更好的语音效果。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发申请中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本申请公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本申请保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本申请的精神和原则之内所作的修改、等同替换和改进等,均应包含在本申请保护范围之内。
Claims (10)
1.一种数据处理方法,应用于数据处理装置中,所述数据处理装置包括高保真4架构,所述数据处理方法包括:
获取待处理的16比特的模型数据;
获取4比特加载指令;
根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
2.根据权利要求1所述的数据处理方法,还包括:
获取4比特加载为8比特的加载指令;
根据所述4比特加载为8比特的加载指令,将所述4比特的模型数据从所述寄存器中加载到8*8乘法器的高4位。
3.根据权利要求2所述的数据处理方法,还包括:
获取4比特运算指令;
根据所述4比特运算指令对所述8*8乘法器中位于高4位的所述4比特的数据进行4比特的点积运算。
4.根据权利要求1所述的数据处理方法,还包括:
获取1比特点积运算指令;
根据1比特点积运算指令对两个1比特的输入数据和模型数据进行异或运算;
计算异或运算结果中1的个数;
将所述1的个数确定为所述两个1比特的输入数据和模型数据点积运算的结果。
5.一种数据处理装置,包括:
第一获取模块,用于获取待处理的16比特的模型数据;
第二获取模块,用于获取4比特加载指令;
第一加载模块,用于根据所述4比特加载指令从所述16比特的模型数据中加载4个4比特的模型数据到64位寄存器中。
6.根据权利要求5所述的装置,还包括:
第三获取模块,用于获取4比特加载为8比特的加载指令;
第二加载模块,用于根据所述4比特加载为8比特的加载指令,将所述4比特的模型数据从所述寄存器中加载到8*8乘法器的高4位。
7.根据权利要求6所述的装置,还包括:
第四获取模块,用于获取4比特运算指令;
第三加载模块,用于根据所述4比特运算指令对所述8*8乘法器中位于高4位的所述4比特的数据进行4比特的点积运算。
8.根据权利要求5所述的装置,还包括:
第五获取模块,用于获取1比特点积运算指令;
异或运算模块,用于根据1比特点积运算指令对两个1比特的输入数据和模型数据进行异或运算;
个数计算模块,用于计算异或运算结果中1的个数;
确定模块,用于将所述1的个数确定为所述两个1比特的输入数据和模型数据点积运算的结果。
9.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-4中任一项所述的方法。
10.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行权利要求1-4中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010844165.2A CN112114874B (zh) | 2020-08-20 | 2020-08-20 | 数据处理方法、装置、电子设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010844165.2A CN112114874B (zh) | 2020-08-20 | 2020-08-20 | 数据处理方法、装置、电子设备和存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112114874A CN112114874A (zh) | 2020-12-22 |
CN112114874B true CN112114874B (zh) | 2021-10-15 |
Family
ID=73804009
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010844165.2A Active CN112114874B (zh) | 2020-08-20 | 2020-08-20 | 数据处理方法、装置、电子设备和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112114874B (zh) |
Family Cites Families (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100265674B1 (ko) * | 1995-06-07 | 2000-09-15 | 데니스 피셸 | 인코드된 데이타 스트림에 대한 에러 검출 및 정정시스템 |
CN100378653C (zh) * | 2005-01-20 | 2008-04-02 | 西安电子科技大学 | 双算术逻辑单元精简指令集8位微控制器 |
CN101083769B (zh) * | 2006-06-02 | 2011-05-25 | 三星电子株式会社 | 处理n比特视频数据的编/解码器和编/解码方法 |
CN101534138B (zh) * | 2008-03-14 | 2013-04-17 | 华为技术有限公司 | 比特加载的方法、用于比特加载的装置及数据传输系统 |
CN104011668B (zh) * | 2011-12-22 | 2017-03-22 | 英特尔公司 | 用于将源操作数映射到不同范围的系统、装置和方法 |
EP3060979B1 (en) * | 2013-10-25 | 2020-08-05 | Advanced Micro Devices, Inc. | Processor and methods for immediate handling and flag handling |
TWI571084B (zh) * | 2014-03-11 | 2017-02-11 | 領特德國公司 | 用以減輕串擾雜訊之裝置 |
CN104951334B (zh) * | 2015-05-22 | 2018-01-23 | 中国电子科技集团公司第十研究所 | FPGA双片QSPI flash的程序加载方法 |
CN112230881A (zh) * | 2016-01-20 | 2021-01-15 | 中科寒武纪科技股份有限公司 | 浮点数处理器 |
WO2018076331A1 (zh) * | 2016-10-31 | 2018-05-03 | 北京中科寒武纪科技有限公司 | 一种神经网络训练方法及装置 |
CN110045960B (zh) * | 2018-01-16 | 2022-02-18 | 腾讯科技(深圳)有限公司 | 基于芯片的指令集处理方法、装置及存储介质 |
CN109002883B (zh) * | 2018-07-04 | 2020-12-29 | 中国科学院计算技术研究所 | 卷积神经网络模型计算装置及计算方法 |
KR102562320B1 (ko) * | 2018-12-24 | 2023-08-01 | 삼성전자주식회사 | 비트 연산 기반의 뉴럴 네트워크 처리 방법 및 장치 |
CN110109646B (zh) * | 2019-03-28 | 2021-08-27 | 北京迈格威科技有限公司 | 数据处理方法、装置和乘加器及存储介质 |
CN110543481B (zh) * | 2019-08-23 | 2022-12-06 | 紫光展锐(重庆)科技有限公司 | 数据处理方法、装置、计算机设备及存储介质 |
CN110659734B (zh) * | 2019-09-27 | 2022-12-23 | 中国科学院半导体研究所 | 深度可分离卷积结构的低比特量化方法 |
CN111162800A (zh) * | 2019-12-25 | 2020-05-15 | 东莞职业技术学院 | 并行卷积编码方法及编码器 |
CN111524540B (zh) * | 2020-07-06 | 2020-11-20 | 延锋伟世通电子科技(南京)有限公司 | 一种新型的汽车音频Digital Chime播放器 |
-
2020
- 2020-08-20 CN CN202010844165.2A patent/CN112114874B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN112114874A (zh) | 2020-12-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111783971A (zh) | 一种用于深度神经网络的可高度灵活配置的数据后处理器 | |
CN111738446B (zh) | 深度学习推理引擎的调度方法、装置、设备和介质 | |
CN111400000A (zh) | 网络请求处理方法、装置、设备和存储介质 | |
CN111966361B (zh) | 用于确定待部署模型的方法、装置、设备及其存储介质 | |
KR102563165B1 (ko) | 메모리 액세스 요청 스케줄링 방법, 장치, 기기 및 저장 매체 | |
CN115880132B (zh) | 图形处理器、矩阵乘法任务处理方法、装置及存储介质 | |
CN111968642A (zh) | 语音数据处理方法、装置及智能车辆 | |
CN110706147A (zh) | 图像处理的环境确定方法、装置、电子设备和存储介质 | |
CN111814959A (zh) | 模型训练数据的处理方法、装置、系统和存储介质 | |
CN111666077B (zh) | 算子处理方法、装置、电子设备及存储介质 | |
CN110705696A (zh) | 神经网络的量化与定点化融合方法及装置 | |
CN111325332B (zh) | 卷积神经网络的处理方法和装置 | |
EP3992774A1 (en) | Method and device for implementing dot product operation, electronic device, and storage medium | |
CN112329919B (zh) | 模型训练方法及装置 | |
CN111767059B (zh) | 深度学习模型的部署方法、装置、电子设备和存储介质 | |
CN111290744B (zh) | 流式计算作业处理方法、流式计算系统及电子设备 | |
CN111767149A (zh) | 调度方法、装置、设备及存储设备 | |
CN107678781B (zh) | 处理器以及用于在处理器上执行指令的方法 | |
CN112114874B (zh) | 数据处理方法、装置、电子设备和存储介质 | |
CN111694648A (zh) | 一种任务调度方法、装置以及电子设备 | |
JP2022024080A (ja) | ニューラルネットワークの積和演算方法及び装置 | |
US20210209471A1 (en) | Processor memory optimization method and apparatus for deep learning training tasks | |
CN111506399B (zh) | 任务迁移方法、装置、电子设备及存储介质 | |
CN112560928A (zh) | 负样本挖掘方法、装置、电子设备及存储介质 | |
CN110782029A (zh) | 神经网络预测方法、装置、电子设备和自动驾驶系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |