CN111381878A - 数据处理装置、方法、芯片及电子设备 - Google Patents

数据处理装置、方法、芯片及电子设备 Download PDF

Info

Publication number
CN111381878A
CN111381878A CN201811625000.5A CN201811625000A CN111381878A CN 111381878 A CN111381878 A CN 111381878A CN 201811625000 A CN201811625000 A CN 201811625000A CN 111381878 A CN111381878 A CN 111381878A
Authority
CN
China
Prior art keywords
data
decompression
processing
decompressed
circuit
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.)
Pending
Application number
CN201811625000.5A
Other languages
English (en)
Inventor
不公告发明人
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shanghai Cambricon Information Technology Co Ltd
Original Assignee
Shanghai Cambricon Information Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Shanghai Cambricon Information Technology Co Ltd filed Critical Shanghai Cambricon Information Technology Co Ltd
Priority to CN201811625000.5A priority Critical patent/CN111381878A/zh
Priority to CN202311044829.7A priority patent/CN117172296A/zh
Priority to PCT/CN2019/121056 priority patent/WO2020114283A1/zh
Publication of CN111381878A publication Critical patent/CN111381878A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • G06F9/3818Decoding for concurrent execution
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30007Arrangements for executing specific machine instructions to perform operations on data operands
    • G06F9/3001Arithmetic instructions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • G06N3/06Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons
    • G06N3/063Physical realisation, i.e. hardware implementation of neural networks, neurons or parts of neurons using electronic means
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

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)
  • Biophysics (AREA)
  • Biomedical Technology (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Computational Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Mathematical Analysis (AREA)
  • Neurology (AREA)
  • Artificial Intelligence (AREA)
  • Computational Linguistics (AREA)
  • Pure & Applied Mathematics (AREA)
  • Evolutionary Computation (AREA)
  • General Health & Medical Sciences (AREA)
  • Molecular Biology (AREA)
  • Computing Systems (AREA)
  • Mathematical Physics (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)
  • Advance Control (AREA)

Abstract

本申请提供一种数据处理装置、方法、芯片及电子设备,该数据处理装置用于执行机器学习计算;所述数据处理装置,包括:处理电路以及控制电路,所述处理电路的第一输入端与所述处理电路的第一输出端连接,所述处理电路包括解压模块,该数据处理装置可以提高解压的正确率;另外,数据处理装置还能够有效节省解压模块的运算量以及存储开销,提高数据处理装置的运算效率。

Description

数据处理装置、方法、芯片及电子设备
技术领域
本发明涉及计算机技术领域,特别是涉及一种数据处理装置、方法、芯片及电子设备。
背景技术
随着数字电子技术的不断发展,各类人工智能(Artificial Intelligence,AI)芯片的快速发展对于高性能数字处理装置的要求也越来越高。神经网络算法作为智能芯片广泛应用的算法之一,通常需要对大量的数据进行不同的运算处理。目前,数据处理装置可以对大量数据压缩后进行运算处理,并且运算处理前需要对压缩数据进行解压后才可以进行正常的运算处理。
但是,现有的数据处理装置是通过其中的一个电路模块对压缩后的所有数据直接进行解压处理,导致解压数据与对应的原始数据相比,解压的正确率较低。
发明内容
基于此,有必要针对上述技术问题,提供一种数据处理装置、方法、芯片及电子设备。
本发明实施例提供一种数据处理装置,所述数据处理装置用于执行机器学习计算;所述数据处理装置包括处理电路以及控制电路,所述处理电路的第一输入端与所述控制电路的第一输出端连接;所述处理电路包括解压模块;
其中,所述控制电路用于解析解压处理的指令得到解压处理参数,并将所述解压处理参数输入至所述解压模块;
所述解压模块用于根据所述解压处理参数,对输入所述解压模块的待解压数据进行解压处理,并得到已解码数据中的数据信息;所述解压模块还用于根据所述数据信息,在所述待解压数据满足触发解压旁路的条件时,将所述待解压数据作为目标解压数据。
在其中一个实施例中,所述解压模块还用于根据已解码数据中的所述信息,判断所述待解压数据不满足触发解压旁路的条件时,则继续对所述待解压数据进行解压处理。
在其中一个实施例中,所述数据处理装置还包括存储电路,所述存储电路用于存储原始数据,所述控制电路用于获取计算指令,并解析所述计算指令得到多个运算指令,将多个所述运算指令输入至所述解压模块中。
在其中一个实施例中,所述存储电路的第一输出端与所述处理电路的第二输入端连接,所述存储电路的第二输出端与所述控制电路的输入端连接,所述存储电路的第一输入端与所述处理电路的输出端连接,所述存储电路的第二输入端与所述控制电路的第二输出端连接。
在其中一个实施例中,所述解压模块分别包括解压处理单元以及选择器,所述解压处理单元的输出端与所述选择器的输入端连接;
其中,所述解压处理单元用于根据所述解压处理参数,对待解压数据进行解压处理,得到已解码数据中的信息,根据已解码数据的所述信息,判断所述待解压数据是否满足触发解压旁路的条件,若不满足,则对所述待解压数据进行后续解压处理,所述选择器用于根据接收到的逻辑判断信号确定,接收所述待解压数据,还是解压处理单元对所述待解压数据进行后续解压处理后得到的解压数据,作为目标解压数据并输出。
本实施例提供的一种数据处理装置,该装置包括处理电路以及控制电路,处理电路包含解压模块,解压模块可以根据控制电路输入的解压处理参数,对待解压数据进行解压处理,若待解压数据满足触发解压旁路的条件时,则解压模块可以直接将该待解压数据,作为目标解压数据输出,不需要对待解压数据进行后续解压处理,从而可以提高解压的正确率;另外,数据处理装置能够有效节省解压模块的运算量以及存储开销,从而提高数据处理装置的运算效率。
本发明实施例提供一种数据处理方法,所述方法包括:
接收待处理数据;
根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息;
根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件,其中,所述触发解压旁路的条件包括待处理数据中包含的压缩标志位对应的信号,表示所述待处理是未采用具体的压缩算法处理得到的;
若满足,则将所述待处理数据作为目标解压数据。
在其中一个实施例中,所述处理参数包括解压处理参数。
在其中一个实施例中,所述根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息,包括:根据所述解压处理参数对所述待处理数据进行解压处理,得到已解码数据的所述信息。
在其中一个实施例中,所述在根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件之后,还包括:若所述待处理数据不满足触发解压旁路的条件时,则将所述待处理数据作为目标解压数据。
在其中一个实施例中,所述将所述待处理数据作为目标解压数据的步骤之后,还包括:通过处理电路对所述目标解压数据进行并行运算处理。
本实施例提供的一种数据处理方法,接收待处理数据,根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件,若满足,则将所述待处理数据作为目标解压数据,该方法节省了数据处理装置进行解压处理的运算量以及数据处理装置的存储开销,进而还可以对待处理数据进行并行处理,得到目标解压数据,有效提高了解压效率;另外,该方法还可以直接将待处理数据作为目标解压数据,以保证解压后的数据与对应的原始数据相比,解压的正确率较高。
本发明实施例提供的一种机器学习运算装置,该机器学习运算装置包括一个或者多个所述的数据处理装置;该机器学习运算装置用于从其它处理装置中获取待运算数据和控制信息,并执行指定的机器学习运算,将执行结果通过I/O接口传递给其它处理装置;
当所述机器学习运算装置包含多个所述数据处理装置时,所述多个所述数据处理装置间可以通过特定的结构进行链接并传输数据;
其中,多个所述数据处理装置通过PCIE总线进行互联并传输数据,以支持更大规模的机器学习的运算;多个所述数据处理装置共享同一控制系统或拥有各自的控制系统;多个所述数据处理装置共享内存或者拥有各自的内存;多个所述数据处理装置的互联方式是任意互联拓扑。
本发明实施例提供的一种组合处理装置,该组合处理装置包括如所述的机器学习处理装置、通用互联接口,和其它处理装置;该机器学习运算装置与上述其它处理装置进行交互,共同完成用户指定的操作;该组合处理装置还可以包括存储装置,该存储装置分别与所述机器学习运算装置和所述其它处理装置连接,用于保存所述机器学习运算装置和所述其它处理装置的数据。
本发明实施例提供的一种神经网络芯片,该神经网络芯片包括上述所述的数据处理装置、上述所述的机器学习运算装置或者上述所述的组合处理装置。
本发明实施例提供的一种神经网络芯片封装结构,该神经网络芯片封装结构包括上述所述的神经网络芯片。
本发明实施例提供的一种板卡,该板卡包括上述所述的神经网络芯片封装结构。
本发明实施例提供了一种电子装置,该电子装置包括上述所述的神经网络芯片或者上述所述的板卡。
本发明实施例提供的一种芯片,包括至少一个如上述任一项所述的数据处理装置。
本发明实施例提供的一种电子设备,包括如所述的芯片。
附图说明
图1为一实施例提供的一种数据处理装置的结构示意图;
图2为另一实施例提供的一种数据处理装置的具体结构示意图;
图3为一实施例提供的一种对数据进行解压处理的方法流程示意图;
图4为一实施例提供的一种组合处理装置的结构图;
图5为一实施例提供的另一种组合处理装置的结构图;
图6为一实施例提供的一种板卡的结构示意图。
具体实施方式
为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行进一步详细说明。应当理解,此处描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。
本申请提供的数据处理装置可应用于AI芯片、现场可编程门阵列FPGA(Field-Programmable Gate Array,FPGA)芯片、或者是其它的硬件电路设备中对数据进行压缩处理,其具体结构示意图如图1所示。
如图1所示为一实施例提供的一种数据处理装置的结构示意图。如图1所示,该数据处理装置用于执行机器学习计算;所述数据处理装置包括处理电路11以及控制电路12,所述处理电路11的第一输入端与所述控制电路12的第一输出端连接,所述处理电路11包括解压模块111;其中,所述控制电路12用于解析解压处理的指令得到解压处理参数,并将所述解压处理参数输入至所述解压模块111,所述解压模块111用于根据所述解压处理参数对待解压数据进行解压处理,并得到已解码数据中的信息;所述解压模块还用于根据所述数据信息,在所述待解压数据满足触发解压旁路的条件时,将所述待解压数据作为目标解压数据。
可选的,所述解压模块111还用于根据已解码数据中的所述信息,判断所述待解压数据不满足触发解压旁路的条件时,则继续对所述待解压数据进行解压处理。
可选的,所述机器学习计算包括:人工神经网络运算。可选的,如图2所示,所述数据处理装置还包括存储电路13,所述存储电路13用于存储原始数据,所述控制电路12用于获取计算指令,并解析所述计算指令得到多个运算指令,将多个所述运算指令输入至所述处理电路11中。
其中,所述存储电路13的第一输出端与所述处理电路11的第二输入端连接,所述存储电路13的第二输出端与所述控制电路12的输入端连接,所述存储电路13的第一输入端与所述处理电路11的输出端连接,所述存储电路13的第二输入端与所述控制电路12的第二输出端连接。
具体的,数据处理装置中的处理电路11通过解压模块111,可以采用具体的解压算法对接收到的待解压数据进行解压处理,在解压过程中可以获得已解码数据中的信息,根据该信息判断待解压数据是否满足触发解压旁路的条件,若满足,则待解压数据可以退出解压处理过程,解压模块111可以将待解压数据,作为对应的目标解压数据直接输出;若解压模块111根据获得的已解码数据中的信息,判断待解压数据不满足触发解压旁路的条件时,则解压模块111可以继续采用具体的解压算法,对待解压数据进行后续解压处理;也就是说,在解压模块111获得已解码数据中的信息时,解压处理过程已经执行一部分了,当解压模块111根据已解码数据中的信息,判断待解压数据不满足触发解压旁路的条件时,则解压模块111可以对待解压数据执行剩余的解压处理过程。其中,剩余的解压处理过程可以称为上述所指的后续解压处理。另外,解压模块111得到目标解压数据后,处理电路11还可以对这些解压数据进行不同的并行运算处理。可选的,待解压数据可以为压缩格式的数据,该压缩格式的数据可以包括首部数据和尾部数据两部分,该尾部数据包含的信息可以为压缩的具体数据,首部数据包含的信息可以包括压缩数据的长度、压缩标志位以及尾部数据地址等信息。可选的,上述处理电路11可以包括主处理电路和/或从处理电路,若处理电路中包括主处理电路和从处理电路时,从处理电路可以为多个。其中,主处理电路和从处理电路中均包含解压模块111,并且通过解压模块111均可以对待解压数据进行解压处理。
可选的,处理电路11中的解压模块111可以接收存储电路13输出的待解压数据,并且还可以接收控制电路12输入的解压处理参数。可选的,解压模块111可以根据接收到的解压处理参数,对待解压数据进行解压处理。可选的,上述解压处理参数可以包括待解压数据中的首部数据地址,解压的数据长度以及解压算法所需的参数等。可选的,上述解压算法所需的参数可以包括哈夫曼解码表,游程解码表,基于字典的解码表以及解压算法等等。一般,解压模块111可以根据解压算法所需的参数,采用对应的解压算法对待解压数据进行解压处理,得到待解压数据中的尾部数据包含的信息,以及首部数据包含的信息,即尾部数据包含的信息可以为压缩的具体数据,首部数据包含的信息可以包括压缩数据的长度、压缩标志位以及尾部数据地址等信息。可选的,数据处理装置可以包括多个处理电路11,图2中只示出了一个处理电路11。可选的,控制电路12可以接收解压处理的指令,并解析该指令得到解压处理参数,并将解压处理参数输入至解压模块111。可选的,上述待解压数据中的首部数据包含的压缩标志位,可以表征该待解压数据是通过具体的压缩算法进行处理得到的,还是该待解压数据是未进行具体的压缩处理直接得到的,同时,该压缩标志位可以包括两种信号,分别用0和1表示,0可以表示采用具体的压缩算法处理后得到的该待解压数据,1可以表示未进行具体的压缩处理直接得到的该待解压数据。
此外,若根据已解码数据中的信息,判断待解压数据满足触发解压旁路的条件时,则解压模块111不需要采用任何解压算法,直接可以将待解压数据作为目标解压数据输出,同时,若根据已解码数据中的信息,判断待解压数据不满足触发解压旁路的条件时,则解压模块111需要继续采用具体的解压算法,对待解压数据进行后续解压处理。可选的,触发解压旁路的条件可以为待解压数据中的首部数据包含的压缩标志位信号,对应表征该待解压数据是未进行具体的压缩处理得到的。
需要说明的是,处理电路11中的解压模块111可以根据控制电路12输入的解压处理参数,对该待解压数据采用具体的解压算法进行解压处理,得到对应的目标解压数据。可选的,解压模块111可以对待解压数据进行并行处理。可选的,每一个待解压数据可以得到一个目标解压数据。可选的,目标解压数据可以为待解压数据未进行压缩处理前的分块数据。可选的,上述压缩标志位可以表征该目标解压数据是通过完整的解压算法进行处理得到的,还是未进行具体的压缩处理直接得到目标解压数据,还可以理解为,该压缩标志位可以包括两种信号,分别为低电平信号0和高电平信号1表示,0可以表示该待解压数据是通过完整的解压算法进行处理得到的,1可以表示该待解压数据是未进行具体的压缩处理直接得到的。可选的,上述待解压数据中尾部数据的分布类型可以为一维紧密型,二维紧密型,三维紧密型,还可以为其它任意维度紧密型。
示例性的,若待解压数据中的尾部数据包含多个数据,一个数据后连续相接下一个数据,依次类推,连续分布多个数据,该种分布形式可以称为一维紧密型;若多个数据分布的形式是固定位宽大小,即可以为8比特位宽的矩阵分布形式,若第一个数据为6比特位宽的数据“010100”,第二个压缩格式数据可以为6比特位宽的数据“101101”,则第二个压缩格式数据的高2位数值“10”可以连续相接第一个数据后,即“01010010”这8个数值位于同一行,第二个数据的低4位数值“1101”可以分布于第二行,然后相连第三个数据,依次类推,每一行存储的数值位数是固定的,多余的数值可以分布于下一行,该种分布形式可以称为二维紧密型;若多个数据分布的形式可以为多个固定大小的矩阵分布,即分别可以为8位*8位的多个矩阵分布形式,若第一个数据为6比特位宽的数据“101101”,第二个压缩格式数据可以为6比特位宽的数据“101101”,则第二个压缩格式数据的高2位数值“10”可以连续相接第一个数据后,即“01010010”这8个数值位于同一行,第二个数据的低4位数值“1101”可以分布于第二行,然后相连第三个数据,依次类推,每一行存储的数值位数是固定的,多余的数值可以分布于下一行,当数据将第一个固定大小的矩阵框分布完后,可以继续将数据分布于第二个固定大小的矩阵框,依次类推,直到将所有数据全部分布完为止,该种分布形式可以称为三维紧密型。
可选的,若处理电路11中包含主处理电路以及从处理电路,则主处理电路中的解压模块111可以将目标解压数据输入至从处理电路,通过从处理电路对目标解压数据进行后续的不同并行运算处理,还可以将目标解压数据返回至存储电路13写入外部存储,等待后续读入。可选的,若处理电路11中只包含多个从处理电路,则每个从处理电路中的解压模块111均可以对目标解压数据进行后续运算处理。
另外,继续参见图2,上述数据处理装置还可以包括直接内存访问单元。可选的,上述数据处理装置中的存储电路13可以包括:寄存器、缓存中任意组合。缓存可以存储输入数据,寄存器可以存储输入数据中标量数据,缓存可以包括高速暂存缓存。可选的,控制电路12可以包括:指令缓存单元121、指令处理单元122以及存储队列单元123,其中,指令缓存单元121可以存储人工神经网络运算关联的计算指令,指令处理单元122可以对计算指令解析得到多个运算指令,存储队列单元123可以存储指令队列,该指令队列可以包括:按该队列的前后顺序待执行的多个运算指令或计算指令。
可选的,上述控制电路12还可以包括依赖关系处理单元124,该依赖关系处理单元124用于在具有多个运算指令时,确定第一运算指令与所述第一运算指令之前的第零运算指令是否存在关联关系,如所述第一运算指令与所述第零运算指令存在关联关系,则将所述第一运算指令缓存在所述指令存储单元内,在所述第零运算指令执行完毕后,从所述指令存储单元提取所述第一运算指令传输至所述运算单元。
所述确定该第一运算指令与第一运算指令之前的第零运算指令是否存在关联关系包括:依据所述第一运算指令提取所述第一运算指令中所需数据(例如矩阵)的第一存储地址区间,依据所述第零运算指令提取所述第零运算指令中所需矩阵的第零存储地址区间,如所述第一存储地址区间与所述第零存储地址区间具有重叠的区域,则确定所述第一运算指令与所述第零运算指令具有关联关系,如所述第一存储地址区间与所述第零存储地址区间不具有重叠的区域,则确定所述第一运算指令与所述第零运算指令不具有关联关系。
本实施例提供的一种数据处理装置,该装置包括处理电路以及控制电路,处理电路解压模块,解压模块可以根据控制电路输入的解压处理参数,对待解压数据进行解压处理,若待解压数据满足触发解压旁路的条件时,则解压模块可以直接将该待解压数据,作为目标解压数据输出,不需要对待解压数据进行后续解压处理,从而可以提高解压的正确率;另外,数据处理装置能够有效节省解压模块的运算量以及存储开销,从而提高数据处理装置的运算效率。
如图2所示为另一个实施例提供的一种数据处理装置中处理电路的具体结构示意图,其中,处理电路中的所述解压模块111包括解压处理单元1111以及选择器1112,所述解压处理单元1111的输出端与所述选择器1112的输入端连接。其中,所述解压处理单元1111用于根据所述解压处理参数,对待解压数据进行解压处理,得到已解码数据中的信息,根据已解码数据的所述信息,判断所述待解压数据是否满足触发解压旁路的条件,若不满足,则对所述待解压数据进行后续解压处理,所述选择器1112用于根据接收到的逻辑判断信号确定,接收所述待解压数据,还是解压处理单元1111对所述待解压数据进行后续解压处理后得到的解压数据,作为目标解压数据并输出。
具体的,解压模块111对待解压数据进行解压处理时,可以默认将待解压数据先输入至解压处理单元1111进行解压处理,解压处理过程执行一部分后,可以得到已解码数据中的信息,解压处理单元1111可以根据该信息判断该待解压数据是否满足触发解压旁路的条件,根据判断结果可以向选择器1112输入一个逻辑判断信号,选择器1112根据接收到的逻辑判断信号确定,解压模块111可以接收待解压数据,作为目标解压数据,还是解压处理单元1111可以继续采用具体的解压算法,对待解压数据进行后续解压处理后得到解压结果,接收解压处理单元1111输出的解压结果,作为目标解压数据输出。可选的,逻辑判断信号可以包括两种,分别表示满足触发解压旁路的条件以及不满触发解压旁路的条件。其中,若选择器1112接收到的信号表示,满足触发解压旁路的条件时,则选择器1112可以直接接收待解压数据,作为目标解压数据输出;若选择器1112接收到的信号表示,不满足触发解压旁路的条件时,则选择器1112可以接收解压处理单元1111继续采用具体的解压算法,对待解压数据进行后续解压处理后得到解压结果,作为目标解压数据输出。可选的,上述解压算法可以包括哈夫曼解码、游程解码以及基于字典的解码算法等。可选的,第解压模块111可以对多个待解压数据进行并行解码处理。可选的,上述解码处理也可以称为解压处理。可选的,选择器1112可以为二路选择器。
以哈夫曼解码算法为例可以对解压算法进行说明,若解压模块111中的解压处理单元1111采用哈夫曼解码算法对一个待解压数据进行解压处理,并且解压模块111可以根据接收到的解压处理参数中,得知具体的解压算法为哈夫曼解码算法。若此时解压处理单元1111只对一个待解压数据进行解压处理,根据解压处理参数中的哈夫曼解码表,以及实际已知的待解压数据中尾部数据的起始地址,从待解压数据的尾部数据中查找解压数据,另外,解压处理单元1111在进行查找处理前,还可以根据哈夫曼解码表得到待解压数据中的首部数据包含的信息,即待解压数据中的尾部数据对应的压缩标志位信号,其中,解压数据可以为原始数据进行压缩处理前得到的分块数据。可选的,若解压处理单元1111接收到的压缩标志位信号,可以表征该待解压数据是未进行压缩处理直接得到的,则该待解压数据可以不再继续进行后续查找处理(即后续解压处理),退出解压处理过程,此时,解压模块111可以通过选择器1112,直接接收待解压数据,作为目标解压数据输出;若解压处理单元1111接收到的压缩标志位信号,可以表征该待解压数据是通过具体的压缩算法进行压缩处理得到的,则该待解压数据可以继续进行后续查找处理(即后续解压处理),此时,解压处理单元1111可以将后续解压处理接收的解压结果,输入至选择器1112中,选择器1112将该解压结果作为目标解压数据并输出。
本实施例提供的一种数据处理装置,解压模块中包括的解压旁路单元以及解压处理单元,若满足触发解压旁路条件的待解压数据可以直接通过解压旁路单元输出作为解压后的数据,此时可以不需要对该待解压数据进行解压处理,进一步节省了解压模块的运算量以及存储开销,从而节省数据处理装置的运算量以及存储开销,并且解压模块可以对多个待解压数据采用并行方式进行解压处理,有效的提高了解压的效率;另外,数据处理装置还可以将待解压数据直接作为解压数据,以保证解压数据与对应的原始数据相比,解压的正确率较高。
图3为一实施例提供的数据处理方法的流程示意图,该方法可以通过图1所示的数据处理装置进行处理,本实施例涉及的是对数据进行解压的过程。如图3所示,该方法包括:
S101、接收待处理数据。
具体的,数据处理装置中的处理电路通过解压模块可以接收存储电路输入的待处理数据。其中,待处理数据格式可以与压缩后的数据格式一致。
S102、根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息。
可选的,所述处理参数可以包括解压处理参数。
可选的,所述根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息,包括:根据所述解压处理参数对所述待处理数据进行解压处理,得到已解码数据的所述信息。
具体的,上述解压处理参数可以包括压缩格式数据的首部数据地址,解压的数据长度以及解压算法所需的参数等。可选的,上述解压处理参数可以是解压模块通过接收控制电路解析得到的,还可以是解压模块预先存储的。可选的,数据处理装置中的解压模块,可以根据接收到的解压处理参数对待解压数据进行解压处理,得到已解码数据的信息。在本实施例中,解压模块根据具体的压缩算法可以对待解压数据执行一部分解压处理过程,就可以得到已解码数据的信息。可选的,上述已解码数据的信息可以等于待解压数据中首部数据包含的信息,即压缩标志位信号。
S103、根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件,其中,所述触发解压旁路的条件包括待处理数据中包含的压缩标志位对应的信号,表示所述待处理是未采用具体的压缩算法处理得到的。
具体的,触发解压旁路的条件可以为待解压数据中的首部数据包含的压缩标志位对应的信号,表示该待解压数据是未进行具体的压缩处理得到的。
S104、若满足,则将所述待处理数据作为目标解压数据。
具体的,如果待处理数据满足触发解压旁路的条件时,解压模块可以将待处理数据作为目标解压数据直接输出。可选的,解压模块均可以对多个待处理数据进行并行解码处理,得到多个目标解压数据。
本实施例提供的一种数据处理方法,接收待处理数据,根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件,若满足,则将所述待处理数据作为目标解压数据,该方法节省了数据处理装置进行解压处理的运算量以及数据处理装置的存储开销,进而还可以对待处理数据进行并行处理,得到目标解压数据,有效提高了解压效率;另外,该方法还可以直接将待处理数据作为目标解压数据,以保证解压后的数据与对应的原始数据相比,解压的正确率较高。
在其中一个实施例中,上述S103在根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件之后,还包括:若所述待处理数据不满足触发解压旁路的条件时,则将所述待处理数据作为目标解压数据。
可选的,所述将所述待处理数据作为目标解压数据的步骤之后,还包括:通过处理电路对所述目标解压数据进行并行运算处理。
具体的,如果待处理数据不满足触发解压旁路的条件时,解压模块可以通过解压处理单元,继续采用具体的解压算法对该待处理数据进行后续解压处理,得到解压结果,并将该解压结果作为目标解压数据。可选的,上述解压处理参数可以包括对待处理数据进行解压的具体解压算法,该解压算法可以为哈夫曼解码,游程解码以及基于字典的解码算法等。可选的,上述解压处理参数可以是解压模块,接收控制电路解析解压运算的指令得到的解压处理参数,还可以是解压模块预先存储的解压处理参数。可选的,上述运算处理可以包括向量累加运算,向量内积运算,向量比较运算以及矩阵转置处理等。
需要说明的是,处理电路中的解压模块可以根据解压处理参数,对待解压数据进行解压处理后得到已解码数据的信息,若根据已解码数据的信息,判断待处理数据满足触发解压旁路的条件时,则解压模块可以直接将待解压数据作为目标解压数据,否则解压模块需要对待解压数据进行后续解压处理后得到解压数据,将该解压数据作为目标解压数据,处理电路可以对目标解压数据进行不同的运算处理得到运算结果,并且处理电路可以对运算结果进行一些后续运算处理,并将后续运算处理的结果返回至分块压缩电路,最后分块压缩电路可以对后续运算处理的结果进行分块处理以及压缩处理后,将压缩后的结果发送至存储电路,存储电路还可以对压缩后的结果进行下一阶段的运算处理。可选的,处理电路可以对目标压缩数据进行解压以及乘法运算,后续处理可以包括解压以及乘法运算等。
另外,处理电路中的解压模块可以根据解压处理参数,对待解压数据进行解压处理,得到目标解压数据,并且处理电路可以对目标解压数据进行不同类型的运算处理得到运算结果,并且处理电路可以将该不同类型的运算结果返回至存储电路,存储电路还可以对该目标解压数据进行下一阶段的运算处理。可选的,处理电路可以对目标解压数据进行累加以及激活运算,上述不同类型的运算结果可以包括累加以及激活运算等。
本实施例提供的一种数据处理方法,若所述待处理数据不满足触发解压旁路的条件时,则继续采用解压算法对所述待处理数据进行后续解压处理,得到目标解压数据,否则,可以将待处理数据直接作为目标解压数据输出,此时,不需要对待解压数据继续进行后续解压处理,进而能够节省解压处理的运算量以及数据处理装置的存储开销。
本申请实施例还提供了一个机器学习运算装置,其包括一个或多个在本申请中提到的数据处理装置,用于从其它处理装置中获取待运算数据和控制信息,执行指定的机器学习运算,执行结果通过I/O接口传递给外围设备。外围设备譬如摄像头,显示器,鼠标,键盘,网卡,wifi接口,服务器。当包含一个以上数据处理装置时,数据处理装置间可以通过特定的结构进行链接并传输数据,譬如,通过快速外部设备互连总线进行互联并传输数据,以支持更大规模的机器学习的运算。此时,可以共享同一控制系统,也可以有各自独立的控制系统;可以共享内存,也可以每个加速器有各自的内存。此外,其互联方式可以是任意互联拓扑。
该机器学习运算装置具有较高的兼容性,可通过快速外部设备互连接口与各种类型的服务器相连接。
本申请实施例还提供了一个组合处理装置,其包括上述的机器学习运算装置,通用互联接口,和其它处理装置。机器学习运算装置与其它处理装置进行交互,共同完成用户指定的操作。图4为组合处理装置的示意图。
其它处理装置,包括中央处理器CPU、图形处理器GPU、神经网络处理器等通用/专用处理器中的一种或以上的处理器类型。其它处理装置所包括的处理器数量不做限制。其它处理装置作为机器学习运算装置与外部数据和控制的接口,包括数据搬运,完成对本机器学习运算装置的开启、停止等基本控制;其它处理装置也可以和机器学习运算装置协作共同完成运算任务。
通用互联接口,用于在所述机器学习运算装置与其它处理装置间传输数据和控制指令。该机器学习运算装置从其它处理装置中获取所需的输入数据,写入机器学习运算装置片上的存储装置;可以从其它处理装置中获取控制指令,写入机器学习运算装置片上的控制缓存;也可以读取机器学习运算装置的存储模块中的数据并传输给其它处理装置。
可选的,该结构如图5所示,还可以包括存储装置,存储装置分别与所述机器学习运算装置和所述其它处理装置连接。存储装置用于保存在所述机器学习运算装置和所述其它处理装置的数据,尤其适用于所需要运算的数据在本机器学习运算装置或其它处理装置的内部存储中无法全部保存的数据。
该组合处理装置可以作为手机、机器人、无人机、视频监控设备等设备的SOC片上系统,有效降低控制部分的核心面积,提高处理速度,降低整体功耗。此情况时,该组合处理装置的通用互联接口与设备的某些部件相连接。某些部件譬如摄像头,显示器,鼠标,键盘,网卡,wifi接口。
在一些实施例里,还申请了一种芯片,其包括了上述机器学习运算装置或组合处理装置。
在一些实施例里,申请了一种芯片封装结构,其包括了上述芯片。
在一些实施例里,申请了一种板卡,其包括了上述芯片封装结构。如图6所示,图6提供了一种板卡,上述板卡除了包括上述芯片389以外,还可以包括其它的配套部件,该配套部件包括但不限于:存储器件390、接收装置391和控制器件392;
所述存储器件390与所述芯片封装结构内的芯片通过总线连接,用于存储数据。所述存储器件可以包括多组存储单元393。每一组所述存储单元与所述芯片通过总线连接。可以理解,每一组所述存储单元可以是DDR SDRAM(英文:Double Data Rate SDRAM,双倍速率同步动态随机存储器)。
DDR不需要提高时钟频率就能加倍提高SDRAM的速度。DDR允许在时钟脉冲的上升沿和下降沿读出数据。DDR的速度是标准SDRAM的两倍。在一个实施例中,所述存储装置可以包括4组所述存储单元。每一组所述存储单元可以包括多个DDR4颗粒(芯片)。在一个实施例中,所述芯片内部可以包括4个72位DDR4控制器,上述72位DDR4控制器中64bit用于传输数据,8bit用于ECC校验。可以理解,当每一组所述存储单元中采用DDR4-3200颗粒时,数据传输的理论带宽可达到25600MB/s。
在一个实施例中,每一组所述存储单元包括多个并联设置的双倍速率同步动态随机存储器。DDR在一个时钟周期内可以传输两次数据。在所述芯片中设置控制DDR的控制器,用于对每个所述存储单元的数据传输与数据存储的控制。
所述接收装置与所述芯片封装结构内的芯片电连接。所述接收装置用于实现所述芯片与外部设备(例如服务器或计算机)之间的数据传输。例如在一个实施例中,所述接收装置可以为标准快速外部设备互连接口。比如,待处理数据由服务器通过标准快速外部设备互连接口传递至所述芯片,实现数据转移。优选的,当采用快速外部设备互连3.0X 16接口传输时,理论带宽可达到16000MB/s。在另一个实施例中,所述接收装置还可以是其它的接口,本申请并不限制上述其它的接口的具体表现形式,所述接口单元能够实现转接功能即可。另外,所述芯片的计算结果仍由所述接收装置传送回外部设备(例如服务器)。
所述控制器件与所述芯片电连接。所述控制器件用于对所述芯片的状态进行监控。具体的,所述芯片与所述控制器件可以通过SPI接口电连接。所述控制器件可以包括单片机(Micro Controller Unit,MCU)。如所述芯片可以包括多个处理芯片、多个处理核或多个处理电路,可以带动多个负载。因此,所述芯片可以处于多负载和轻负载等不同的工作状态。通过所述控制装置可以实现对所述芯片中多个处理芯片、多个处理和或多个处理电路的工作状态的调控。
在一些实施例里,申请了一种电子设备,其包括了上述板卡。
电子设备可以为数据处理器、机器人、电脑、打印机、扫描仪、平板电脑、智能终端、手机、行车记录仪、导航仪、传感器、摄像头、服务器、云端服务器、相机、摄像机、投影仪、手表、耳机、移动存储、可穿戴设备、交通工具、家用电器、和/或医疗设备。
所述交通工具包括飞机、轮船和/或车辆;所述家用电器包括电视、空调、微波炉、冰箱、电饭煲、加湿器、洗衣机、电灯、燃气灶、油烟机;所述医疗设备包括核磁共振仪、B超仪和/或心电图仪。
需要说明的是,对于前述的各方法实施例,为了简单描述,故将其都表述为一系列的电路组合,但是本领域技术人员应该知悉,本申请并不受所描述的电路组合方式的限制,因为依据本申请,某些电路可以采用其它方式或者结构实现。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的器件和模块并不一定是本申请所必须的。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其它实施例的相关描述。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对本发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。

Claims (17)

1.一种数据处理装置,其特征在于,所述数据处理装置用于执行机器学习计算;所述数据处理装置包括处理电路以及控制电路,所述处理电路的第一输入端与所述控制电路的第一输出端连接;所述处理电路包括解压模块;
其中,所述控制电路用于解析解压处理的指令得到解压处理参数,并将所述解压处理参数输入至所述解压模块;
所述解压模块用于根据所述解压处理参数,对输入所述解压模块的待解压数据进行解压处理,并得到已解码数据中的数据信息;所述解压模块还用于根据所述数据信息,在所述待解压数据满足触发解压旁路的条件时,将所述待解压数据作为目标解压数据。
2.根据权利要求1所述的数据处理装置,其特征在于,所述解压模块还用于根据已解码数据中的所述信息,判断所述待解压数据不满足触发解压旁路的条件时,则继续对所述待解压数据进行解压处理。
3.根据权利要求1-2中所述的数据处理装置,其特征在于,所述数据处理装置还包括存储电路,所述存储电路用于存储原始数据,所述控制电路用于获取计算指令,并解析所述计算指令得到多个运算指令,将多个所述运算指令输入至所述解压模块中。
4.根据权利要求3所述的数据处理装置,其特征在于,所述存储电路的第一输出端与所述处理电路的第二输入端连接,所述存储电路的第二输出端与所述控制电路的输入端连接,所述存储电路的第一输入端与所述处理电路的输出端连接,所述存储电路的第二输入端与所述控制电路的第二输出端连接。
5.根据权利要求1所述的数据处理装置,其特征在于,所述解压模块分别包括解压处理单元以及选择器,所述解压处理单元的输出端与所述选择器的输入端连接;
其中,所述解压处理单元用于根据所述解压处理参数,对待解压数据进行解压处理,得到已解码数据中的信息,根据已解码数据的所述信息,判断所述待解压数据是否满足触发解压旁路的条件,若不满足,则对所述待解压数据进行后续解压处理,所述选择器用于根据接收到的逻辑判断信号确定,接收所述待解压数据,还是解压处理单元对所述待解压数据进行后续解压处理后得到的解压数据,作为目标解压数据并输出。
6.一种数据处理方法,其特征在于,所述方法包括:
接收待处理数据;
根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息;
根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件,其中,所述触发解压旁路的条件包括待处理数据中包含的压缩标志位对应的信号,表示所述待处理是未采用具体的压缩算法处理得到的;
若满足,则将所述待处理数据作为目标解压数据。
7.根据权利要求6所述的方法,其特征在于,所述处理参数包括解压处理参数。
8.根据权利要求7所述的方法,其特征在于,所述根据所述处理参数对所述待处理数据进行解压处理,得到已解码数据的信息,包括:根据所述解压处理参数对所述待处理数据进行解压处理,得到已解码数据的所述信息。
9.根据权利要求6所述的方法,其特征在于,所述在根据已解码数据的所述信息,判断所述待处理数据是否满足触发解压旁路的条件之后,还包括:若所述待处理数据不满足触发解压旁路的条件时,则将所述待处理数据作为目标解压数据。
10.根据权利要求9所述的方法,其特征在于,所述将所述待处理数据作为目标解压数据的步骤之后,还包括:通过处理电路对所述目标解压数据进行并行运算处理。
11.一种机器学习运算装置,其特征在于,所述机器学习运算装置包括一个或多个如权利要求1-5任一项所述的数据处理装置,用于从其它处理装置中获取待运算输入数据和控制信息,并执行指定的机器学习运算,将执行结果通过I/O接口传递给其它处理装置;
当所述机器学习运算装置包含多个所述数据处理装置时,所述多个所述计算装置间可以通过特定的结构进行连接并传输数据;
其中,多个所述数据处理装置通过PCIE总线进行互联并传输数据,以支持更大规模的机器学习的运算;多个所述数据处理装置共享同一控制系统或拥有各自的控制系统;多个所述数据处理装置共享内存或者拥有各自的内存;多个所述数据处理装置的互联方式是任意互联拓扑。
12.一种组合处理装置,其特征在于,所述组合处理装置包括如权利要求11所述的机器学习运算装置,通用互联接口和其它处理装置;
所述机器学习运算装置与所述其它处理装置进行交互,共同完成用户指定的计算操作。
13.根据权利要求12所述的组合处理装置,其特征在于,还包括:存储装置,该存储装置分别与所述机器学习运算装置和所述其它处理装置连接,用于保存所述机器学习运算装置和所述其它处理装置的数据。
14.一种神经网络芯片,其特征在于,所述机器学习芯片包括如权利要求11所述的机器学习运算装置或如权利要求12所述的组合处理装置或如权利要求12所述的组合处理装置。
15.一种电子设备,其特征在于,所述电子设备包括如所述权利要求14所述的芯片。
16.一种板卡,其特征在于,所述板卡包括:存储器件、接收装置和控制器件以及如权利要求14所述的神经网络芯片;
其中,所述神经网络芯片与所述存储器件、所述控制器件以及所述接收装置分别连接;
所述存储器件,用于存储数据;
所述接收装置,用于实现所述芯片与外部设备之间的数据传输;
所述控制器件,用于对所述芯片的状态进行监控。
17.根据权利要求16所述的板卡,其特征在于,
所述存储器件包括:多组存储单元,每一组所述存储单元与所述芯片通过总线连接,所述存储单元为:DDR SDRAM;
所述芯片包括:DDR控制器,用于对每个所述存储单元的数据传输与数据存储的控制;
所述接收装置为:标准PCIE接口。
CN201811625000.5A 2018-12-07 2018-12-28 数据处理装置、方法、芯片及电子设备 Pending CN111381878A (zh)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN201811625000.5A CN111381878A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备
CN202311044829.7A CN117172296A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备
PCT/CN2019/121056 WO2020114283A1 (zh) 2018-12-07 2019-11-26 数据处理方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811625000.5A CN111381878A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备

Related Child Applications (1)

Application Number Title Priority Date Filing Date
CN202311044829.7A Division CN117172296A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备

Publications (1)

Publication Number Publication Date
CN111381878A true CN111381878A (zh) 2020-07-07

Family

ID=71215033

Family Applications (2)

Application Number Title Priority Date Filing Date
CN201811625000.5A Pending CN111381878A (zh) 2018-12-07 2018-12-28 数据处理装置、方法、芯片及电子设备
CN202311044829.7A Pending CN117172296A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备

Family Applications After (1)

Application Number Title Priority Date Filing Date
CN202311044829.7A Pending CN117172296A (zh) 2018-12-28 2018-12-28 数据处理装置、方法、芯片及电子设备

Country Status (1)

Country Link
CN (2) CN111381878A (zh)

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102905132A (zh) * 2012-10-16 2013-01-30 上海大学 无线视频传输的压缩和解压缩方法及其装置
CN103384884A (zh) * 2012-12-11 2013-11-06 华为技术有限公司 一种文件压缩方法、文件解压缩方法、装置及服务器
CN108271026A (zh) * 2016-12-30 2018-07-10 上海寒武纪信息科技有限公司 压缩/解压缩的装置和系统、芯片、电子装置

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102905132A (zh) * 2012-10-16 2013-01-30 上海大学 无线视频传输的压缩和解压缩方法及其装置
CN103384884A (zh) * 2012-12-11 2013-11-06 华为技术有限公司 一种文件压缩方法、文件解压缩方法、装置及服务器
CN108271026A (zh) * 2016-12-30 2018-07-10 上海寒武纪信息科技有限公司 压缩/解压缩的装置和系统、芯片、电子装置

Also Published As

Publication number Publication date
CN117172296A (zh) 2023-12-05

Similar Documents

Publication Publication Date Title
CN110163363B (zh) 一种计算装置及方法
CN110059797B (zh) 一种计算装置及相关产品
CN111382853B (zh) 数据处理装置、方法、芯片及电子设备
CN111381882B (zh) 数据处理装置及相关产品
CN111382852B (zh) 数据处理装置、方法、芯片及电子设备
CN111382856B (zh) 数据处理装置、方法、芯片及电子设备
CN111381875B (zh) 数据比较器、数据处理方法、芯片及电子设备
CN111381878A (zh) 数据处理装置、方法、芯片及电子设备
CN111382855B (zh) 数据处理装置、方法、芯片及电子设备
CN111723920A (zh) 人工智能计算装置及相关产品
CN111384944B (zh) 全加器、半加器、数据处理方法、芯片及电子设备
CN112395003A (zh) 运算方法、装置及相关产品
CN111382850A (zh) 运算方法、装置及相关产品
CN111381873A (zh) 运算方法、装置及相关产品
CN111381872A (zh) 运算方法、装置及相关产品
CN111260070A (zh) 运算方法、装置及相关产品
CN111381802B (zh) 数据比较器、数据处理方法、芯片及电子设备
CN214504452U (zh) 一种用于神经网络推理的异构系统
CN112232498B (zh) 一种数据处理装置、集成电路芯片、电子设备、板卡和方法
CN111382390B (zh) 运算方法、装置及相关产品
CN111723921A (zh) 人工智能计算装置及相关产品
CN111381806A (zh) 数据比较器、数据处理方法、芯片及电子设备
CN113033791A (zh) 用于保序的计算装置、集成电路装置、板卡及保序方法
CN111381803A (zh) 数据比较器、数据处理方法、芯片及电子设备
CN111381804A (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
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20200707