CN111258535B - 一种用于fpga实现的排序方法 - Google Patents

一种用于fpga实现的排序方法 Download PDF

Info

Publication number
CN111258535B
CN111258535B CN202010040801.6A CN202010040801A CN111258535B CN 111258535 B CN111258535 B CN 111258535B CN 202010040801 A CN202010040801 A CN 202010040801A CN 111258535 B CN111258535 B CN 111258535B
Authority
CN
China
Prior art keywords
data
valid
read
ram
address
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
Application number
CN202010040801.6A
Other languages
English (en)
Other versions
CN111258535A (zh
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.)
Jiangsu Fangtian Power Technology Co Ltd
Original Assignee
Jiangsu Fangtian Power 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 Jiangsu Fangtian Power Technology Co Ltd filed Critical Jiangsu Fangtian Power Technology Co Ltd
Priority to CN202010040801.6A priority Critical patent/CN111258535B/zh
Publication of CN111258535A publication Critical patent/CN111258535A/zh
Application granted granted Critical
Publication of CN111258535B publication Critical patent/CN111258535B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/22Arrangements for sorting or merging computer data on continuous record carriers, e.g. tape, drum, disc
    • G06F7/24Sorting, i.e. extracting data from one or more carriers, rearranging the data in numerical or other ordered sequence, and rerecording the sorted data on the original carrier or on a different carrier or set of carriers sorting methods in general
    • 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/3867Concurrent instruction execution, e.g. pipeline or look ahead using instruction pipelines
    • G06F9/3869Implementation aspects, e.g. pipeline latches; pipeline synchronisation and clocking

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Logic Circuits (AREA)

Abstract

本发明公开了一种用于FPGA实现的排序方法,在排序需求发起后,采用读取控制模块进行第一次遍历读取数据,分别送入两个数据通道,其中A通道存放每次遍历的读取到的第一数,B通道存放按顺序存放剩下的数据。将A通道和B通道的数据送入比较器进行比较,比较的结果在计数控制模块的控制下,写入相应的计数存储RAM;第一次遍历完成后,进行第二次遍历,第二遍历的起始地址在第一次遍历的基础上加1。重复第一次遍历的操作。对于数据量为N的序列而言,从需要进行N‑1轮遍历。等到第N‑1轮结束后,比较计数的过程结束。在结果模块的控制下,得到原数据在序列中所对应的新的索引值,从而得到有序的序列。

Description

一种用于FPGA实现的排序方法
技术领域
本发明涉及数据处理技术领域,特别是一种用于FPGA实现的排序方法。
背景技术
排序是计算机领域中必不可少的基本数据处理操作。通过排序可以使得数据能够以一定的顺序进行全排列,减少后续操作的时间。在目前的软件实现中,已经有很多比较经典的排序算法,比如:插入排序、快速排序、冒泡排序等。但是这些排序算法大都是针对软件设计的采用串行执行的方式,不利于实时性较高的工程实现。
现代CPU主要利用线程的本地存储层次优化数据在存储单元中的排列,以减少访存次数以及减少访存缺失,同时利用单指令多数据流技术,来提高算法的数据级并行度;GPU则需要将多个线程组织成线程块,依靠共享内存提高线程块的访存速度,而在线程块内则使用单指令多线程技术提高线程的执行效率。FPGA则是依靠硬件描述语言或高级综合语言优化电路设计,提高资源利用率的同时提高FPGA的吞吐量。
文献“吕伟新,李清清,娄俊岭.FPGA比较矩阵排序法及在中值滤波器中的应用[J].电子器件,2012,35(1):34-38.”中所提出的比较排序法很好的适应了FPGA的并行性的特点。但是随着同时输入元素的增加,需要的FPGA逻辑单元也呈指数增加,无法完成过多输入元素的同时排序。
发明内容
本发明所要解决的技术问题是克服现有技术的不足而提供一种用于FPGA实现的排序方法,本发明通过将二维比较矩阵拆分成两个一维RAM,在保证排序结果准确性的同时,能够利用流水线操作,提高排序效率以及解决了原组合逻辑带来的时序影响,并且支持多种类型数据的排序。
本发明为解决上述技术问题采用以下技术方案:
根据本发明提出的一种用于FPGA实现的排序方法,采用数据排序RAM存储待排序数据,采用读取控制模块读取排序数据并传输至比较器,待排序数据的数目为N,读取控制模块访问数据排序RAM的次数为N-1,每次执行排序时将数据排序RAM的装载地址LOAD_ADDR初始化为0;
读取控制模块执行以下步骤:
步骤1.1:若是第一次读取,则设置首次读取标志first_read有效,否则设为无效;
步骤1.2:首先设置数据排序RAM的读取地址为装载地址LOAD_ADDR,然后每个时钟节拍对数据排序RAM的读取地址进行加1操作,直至读取地址为N-1停止,从LOAD_ADDR读取的数据锁存为数据A,在步骤1.2中,数据A保持不变,从LOAD_ADDR+1到N-1读取的数据锁存为数据组B,所述数据A只包含一个数据,所述数据组B包含N-LOAD_ADDR-1个数据,所述数据A与数据组B参与比较器的比较排序运算,设置数据组B有效标志valid为有效且保持在N-LOAD_ADDR-1个时钟节拍内始终保持有效;
步骤1.3:LOAD_ADDR加1,若LOAD_ADDR等于N-1,则终止本次操作,否则跳转到步骤1.1;
采用比较器比较输入到比较器的数据A与数据组B,若比较结果为数据A排在前面,则设置比较结果信号A_first为有效、否则设为无效;若比较器完成数据比较需要K个时钟周期,则采用延迟模块将读取控制模块输出的数据组B的有效标志valid与首次读取标志frist_read延迟K个时钟周期,所述有效标志valid延迟为经过延迟的有效标志valid_delay,所述首次读取标志first_read延迟为经过延迟的首次读取标志first_read_delay;所述比较器将比较结果A_first传输到计数模块,所述延迟模块将经过延迟的有效标志valid_delay和首次读取标志first_read_delay传输到计数模块,得到原数据在序列中所对应的新的索引值,从而得到有序的序列。
作为本发明所述的一种用于FPGA实现的排序方法进一步优化方案,计数模块包括行计数模块、列计数模块以及用于计数的行计数RAM与列计数双口RAM。
作为本发明所述的一种用于FPGA实现的排序方法进一步优化方案,行计数模块在有效标志valid有效的时候对A_first取反的结果进行累加,在有效标志valid无效的时候把该结果写入到行计数RAM中,在首次读取标志first_read_delay有效的时候设置所述行计数RAM的写入地址为0,所述结果写入行计数RAM后,行计数RAM的地址加1。
作为本发明所述的一种用于FPGA实现的排序方法进一步优化方案,所述列计数控制在valid_delay信号有效时将A_first与列计数双口RAM的数据进行累加,然后结果存储到列计数双口RAM中。
作为本发明所述的一种用于FPGA实现的排序方法进一步优化方案,计数模块采用双端口的访问模式来完成,列计数双口RAM的初始化地址initial_addr=1,计数模块采用以下方法步骤:
步骤6.1:当valid有效并且first_read_delay有效时,将比较结果加0,新的结果从初始地址initial_addr开始按照地址递增的顺序,写入RAM,直至写到地址N-1为止;
步骤6.2:initial_addr加1,当valid有效并且first_valid无效时,从地址为initial_addr开始,按照地址递增的顺序将当前地址的数据读出并与当前产生的比较值相加,结果重新写入该地址,直到地址为N-1;
步骤6.3:重复步骤6.2,直到initial_addr=N-2。
本发明采用以上技术方案与现有技术相比,具有以下技术效果:
本发明利用行/列计数双口RAM实现一个二维的比较计数矩阵,对比较计数矩阵采用对角线取反方法,使得时间复杂度变为
Figure BDA0002367692700000031
降低了时间复杂度;对于一组待排序的数据而言,能够利用流水线操作,提高运算的吞吐量,提高了整体的排序性能;整个排序过程,共用同一个比较器,节省了FPGA资源,但是实现了海量数据的排序。
附图说明
图1是排序的系统结构框图。
图2是本次发明的比较矩阵理论分析图。
图3是实施例一波形图。
图4是实施例一波形图。
具体实施方式
为了使本发明的目的、技术方案和优点更加清楚,下面将结合附图及具体实施例对本发明进行详细描述。
本发明包括数据存储RAM、排序数据读取控制模块、比较器、计数控制模块、计数存储RAM和结果模块。在排序需求发起后,排序数据读取控制模块进行第一次遍历读取数据,分别送入两个数据通道,其中A通道存放每次遍历的读取到的第一数,B通道存放按顺序存放剩下的数据。将A通道和B通道的数据送入比较器进行比较,比较的结果在计数控制模块的控制下,写入相应的计数存储RAM。第一次遍历完成后,进行第二次遍历,第二遍历的起始地址在第一次遍历的基础上加1。重复第一次遍历的操作。对于数据量为N的序列而言,从需要进行N-1轮遍历。等到第N-1轮结束后,比较计数的过程结束。在结果模块的控制下,得到原数据在序列中所对应的新的索引值,从而得到有序的序列。
参见图1,本发明的基于比较矩阵的高效排序算法的FPGA实现方法的操作步骤如下:
在FPGA上建立数据排序RAM模块、读取控制模块、数据A、数据组B、比较器、延迟模块、计数模块、索引统计。
为了便于描述,假定一组待排序的数据量为N,则总共需要访问数据排序RAM的次数为N-1次。第i次访问的起始地址为(i-1),第i次访问共需要遍历(N-i+1)个数据。进一步的说明。对于每组待排序的数据而言,分为第1次访问数据排序RAM和第i(i≠1)次访问数据排序RAM。
第1次访问数据排序RAM,在读取控制的作用下,给出起始访问地址LOAD_ADDR=0,按照地址递增的顺序将存放在RAM中的数据读出,直到地址N-1结束。读取完成后,LOAD_ADDR加1。其中第1个读取到的数据送入数据A进行锁存,从LOAD_ADDR+1到N-1读取的数据锁存为数据组B。所述数据A只包含一个数据,所述数据组B包含N-LOAD_ADDR-1个数据,当数据通道B有数据时,将valid信号拉高并保持N-LOAD_ADDR-1个时钟节拍内有效,表明通道A和通道B中有数据可以进行比较。当读取结束后,valid信号拉低置0。在valid有效时,数据通道A和数据通道B的数据送入比较器进行数据比较。如果数据A的数据大于等于数据组B的数据,输出的A_first置1,否则置0。与此同时,由于比较器的结果输出有延迟,所以将valid信号经过延迟模块,得到valid_delay信号,使得valid信号与比较器输出的结果信号时序对齐,标志比较结果有效。由于本次为第1次访问数据排序RAM,所以将first_read信号拉高置1,经过延迟模块,得到first_valid_delay信号,延迟的时钟节拍数与valid信号相同。行/列计数模块通过判断valid信号和first_valid信号给出不同的控制信息。对于行计数模块而言,在valid有效的时候对A_first信号取反的结果进行累加,累加的结果在valid信号无效的时候写入行计数RAM,写入完成后,行计数RAM地址加1。对于列计数模块而言,设置列计数双口RAM的初始化地址initial_addr=1,从initial_addr所指地址开始,按照地址递增的顺序,将A_first加0的结果写入当前的地址中,直到地址N-1结束。结束后,将initial_addr的值加1。第1次访问数据排序RAM的所有流程结束。
第i次访问数据排序RAM。由于不是第一次访问所以first_read信号置为0。在读取控制模块的作用下,从起始地址LOAD_ADDR=(i-1)开始读取数据,直到地址N-1结束。读取完成后,LOAD_ADDR加1。接下来的过程与第一次流程的相同,不同的地方在于图1中的计数模块。经过前级的操作可以得到A_first、valid_delay、first_read_delay信号。对于行计数模块而言,通过判断valid信号,在valid有效的时候对A_first信号取反的结果进行累加,累加的结果在valid信号无效的时候写入行计数RAM,写入完成后,行计数RAM地址加1。对于列计数模块而言,在valid有效,first_valid无效的时候,按照地址递增的顺序,从initial_addr所指地址开始,将列计数双口RAM中地址所对应的数据从端口1读出并与A_first相加,相加的结果从端口2写回该地址,直到地址N-1结束。结束后,将initial_addr的值加1。从而第i次访问数据排序RAM流程结束。
参见图2,经过N-1次访问数据排序RAM,得到了所有数据的比较结果值。最后,从地址0开始,按地址递增的顺序,将行计数RAM和列计数双口RAM中相同地址中的数读取出来相加,直到地址N-1结束,便得到了原始数据所对应的新的索引值。
实施例一
参考图3。对一组数据量为4的序列进行降序排序,总需要访问3次数据RAM。数据4,3,9,6按照地址递增得顺序存放在数据RAM中。第1次访问数据排序RAM。给出地址0、1、2、3,经过两个时钟延迟,读到结果4、3、9、6。第一个读取到的数4送入数据A锁存;3、9、6送入数据组B寄存。在数据3、9、6有效期间,valid保持高电平有效。表明可以对数据A和数据组B中的数进行比较。比较的判别方式为:如果数据A大于等于数据组B,则A_first为1,否则为0。比较的结果经过3个时钟的延迟得到输出结果A_first。由于是第一次访问,所以first_read在第1轮读出的数据有效期内保持高电平。对first_read和valid信号经过3个时钟的延迟,得到了valid_delay和first_read_delay信号。当valid_delay信号有效的时候,将A_first信号取反累加,累加的结果在valid信号无效的时候写入行计数RAM的地址0。行计数RAM的地址加1。将当前A_first值加0的结果写入列计数RAM的地址1、2、3。第一次访问结束。第2次访问给出地址1、2、3,由于采用流水线操作,不需要再第一次的基础上再额外等待2个时钟的延迟。如图3所示,直接在第一次读取数据后便可以得到第二次访问读取结果3、9、6。在数据9、6有效期间,valid保持高电平有效,由于不是第一次访问,所以first_read信号无效。经过3拍的延迟,得到了比较结果A_first以及valid_delay和first_read_delay信号。当valid_delay信号有效的时候,将A_first信号取反累加,累加的结果在valid信号无效的时候写入行计数RAM的地址1。行计数RAM的地址加1。当valid有效,first_valid无效的时候,从地址2开始,将列计数RAM中的数读出,读出的数与当前的比较结果相加,相加的结果再写回该地址,如图上红色和蓝色线圈所示。第三次重复第二次的过程。
参见图4。可以看到比较结束后,行/列计数RAM中个地址中的统计数值。将两个计数RAM相同地址中的数据读出相加,便得到了原始数据所对应的新的索引值。如果中所示,括号中4所对应的索引值为2。按照索引值从小到大的顺序将数据输出,便得到了一组降序序列9,6,4,3。与理论分析结果一致。
本发明是一种基于比较矩阵的高效排序算法的FPGA实现方法,包括以下步骤:待排序的数据预先存储在数据排序RAM中,通过读取控制模块将RAM中的数据读出。在一组数据量为N的排序过程中,共需要读取控制(N-1)次。其中对于每一次读出的第1个数据在锁存信号有效的情况下,将数据锁存在数据A,其余读出的数依次锁存在数据组B并依次与第一个读出的数据送入比较器进行比较并获得比较结果,如果数据A的数大于等于数据组B的数,则数据A的数得1分,否则得0分。然后将比较的结果在行/列计数模块的控制下,对比较的结果进行处理存放在行/列计数RAM中。最后统计分析行/列计数RAM中的数值得到原始数据的新的索引值,从而获得一组有序队列。
本发明基于比较矩阵的高效排序算法的FPGA实现方法用两个一维的数据缓存空间RAM实现了二维的数据比较矩阵。在能够满足时序要求的同时,可以减少时间复杂度,提高数据的吞吐量,数据实时性,能够满足电力物联网海量数据的排序处理要求。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到的变化或替换,都应涵盖在本发明的保护范围内。

Claims (5)

1.一种用于FPGA实现的排序方法,其特征在于,采用数据排序RAM存储待排序数据,采用读取控制模块读取排序数据并传输至比较器,待排序数据的数目为N,读取控制模块访问数据排序RAM 的次数为N-1,每次执行排序时将数据排序RAM的装载地址LOAD_ADDR初始化为0;N为大于1的整数;
读取控制模块执行以下步骤:
步骤1.1:若是第一次读取,则设置首次读取标志first_read有效,否则设为无效;
步骤1.2:首先设置数据排序RAM的读取地址为装载地址LOAD_ADDR,然后每个时钟节拍对数据排序RAM的读取地址进行加1操作,直至读取地址为N-1停止,从LOAD_ADDR读取的数据锁存为数据A,在步骤1.2中,数据A保持不变,从LOAD_ADDR+1到N-1读取的数据锁存为数据组B,所述数据A只包含一个数据,所述数据组B包含N-LOAD_ADDR-1个数据,所述数据A与数据组B参与比较器的比较排序运算,设置数据组B有效标志valid为有效且保持在N-LOAD_ADDR-1个时钟节拍内始终保持有效;
步骤1.3:LOAD_ADDR加1,若LOAD_ADDR等于N-1,则终止本次操作,否则跳转到步骤1.1;
采用比较器比较输入到比较器的数据A与数据组B,若比较结果为数据A排在前面,则设置比较结果信号A_first为有效、否则设为无效;若比较器完成数据比较需要K个时钟周期,则采用延迟模块将读取控制模块输出的数据组B的有效标志valid与首次读取标志frist_read延迟K个时钟周期,所述有效标志valid延迟为经过延迟的有效标志valid_delay,所述首次读取标志first_read延迟为经过延迟的首次读取标志first_read_delay;所述比较器将比较结果A_first传输到计数模块,所述延迟模块将经过延迟的有效标志valid_delay和首次读取标志first_read_delay传输到计数模块,得到原数据在序列中所对应的新的索引值,从而得到有序的序列。
2.根据权利要求1所述的一种用于FPGA实现的排序方法,其特征在于,计数模块包括行计数模块、列计数模块以及用于计数的行计数RAM与列计数双口RAM。
3.根据权利要求2所述的一种用于FPGA实现的排序方法,其特征在于,行计数模块在有效标志valid有效的时候对A_first取反的结果进行累加,在有效标志valid无效的时候把该结果写入到行计数RAM中,在首次读取标志first_read_delay有效的时候设置所述行计数RAM的写入地址为0,所述结果写入行计数RAM后,行计数RAM的地址加1。
4.根据权利要求2所述的一种用于FPGA实现的排序方法,其特征在于,所述列计数控制在valid_delay信号有效时将A_first与列计数双口RAM的数据进行累加,然后结果存储到列计数双口RAM中。
5.根据权利要求4所述的一种用于FPGA实现的排序方法,其特征在于,计数模块采用双端口的访问模式来完成,列计数双口RAM的初始化地址initial_addr=1,计数模块采用以下方法步骤:
步骤6.1:当valid有效并且first_read_delay有效时,将比较结果加0,新的结果从初始地址initial_addr开始按照地址递增的顺序,写入RAM,直至写到地址N-1为止;
步骤6.2:initial_addr 加1,当valid有效并且first_valid无效时,从地址为initial_addr开始,按照地址递增的顺序将当前地址的数据读出并与当前产生的比较值相加,结果重新写入该地址,直到地址为N-1;
步骤6.3:重复步骤6.2,直到initial_addr=N-2。
CN202010040801.6A 2020-01-15 2020-01-15 一种用于fpga实现的排序方法 Active CN111258535B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010040801.6A CN111258535B (zh) 2020-01-15 2020-01-15 一种用于fpga实现的排序方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010040801.6A CN111258535B (zh) 2020-01-15 2020-01-15 一种用于fpga实现的排序方法

Publications (2)

Publication Number Publication Date
CN111258535A CN111258535A (zh) 2020-06-09
CN111258535B true CN111258535B (zh) 2022-06-17

Family

ID=70947019

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010040801.6A Active CN111258535B (zh) 2020-01-15 2020-01-15 一种用于fpga实现的排序方法

Country Status (1)

Country Link
CN (1) CN111258535B (zh)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111796306B (zh) * 2020-07-31 2023-05-02 北京中捷时代航空科技有限公司 一种导航卫星信号接收方法及接收机
CN114791892A (zh) * 2021-01-25 2022-07-26 京东方科技集团股份有限公司 一种数据传输方法和装置
CN113900622B (zh) * 2021-09-22 2022-04-08 中国科学院国家空间科学中心 一种基于fpga的数据信息快速排序方法、系统、设备及存储介质
CN113672530B (zh) * 2021-10-21 2022-02-18 苏州浪潮智能科技有限公司 一种服务器及其排序设备
CN114528111B (zh) * 2022-02-17 2023-06-16 北京有竹居网络技术有限公司 用于数据召回的fpga芯片和数据召回方法

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6226779B1 (en) * 1997-09-29 2001-05-01 Xilinx, Inc. Programmable IC with gate array core and boundary scan capability
CN104393961A (zh) * 2014-12-12 2015-03-04 成都朗锐芯科技发展有限公司 一种接收包排序及无效包处理方法
CN105045557A (zh) * 2015-09-06 2015-11-11 四川九洲电器集团有限责任公司 一种基于双口缓存的累加求和方法和装置
CN110058201A (zh) * 2019-04-22 2019-07-26 西安电子工程研究所 一种基于fpga资源复用实现多波形多速率时域脉压的方法
CN110362529A (zh) * 2019-07-10 2019-10-22 中国科学院近代物理研究所 一种能量粒子探测器信号处理系统及方法
CN110633154A (zh) * 2019-09-06 2019-12-31 中国科学院近代物理研究所 一种数据全排序方法及系统

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6844757B2 (en) * 2002-06-28 2005-01-18 Lattice Semiconductor Corp. Converting bits to vectors in a programmable logic device

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6226779B1 (en) * 1997-09-29 2001-05-01 Xilinx, Inc. Programmable IC with gate array core and boundary scan capability
CN104393961A (zh) * 2014-12-12 2015-03-04 成都朗锐芯科技发展有限公司 一种接收包排序及无效包处理方法
CN105045557A (zh) * 2015-09-06 2015-11-11 四川九洲电器集团有限责任公司 一种基于双口缓存的累加求和方法和装置
CN110058201A (zh) * 2019-04-22 2019-07-26 西安电子工程研究所 一种基于fpga资源复用实现多波形多速率时域脉压的方法
CN110362529A (zh) * 2019-07-10 2019-10-22 中国科学院近代物理研究所 一种能量粒子探测器信号处理系统及方法
CN110633154A (zh) * 2019-09-06 2019-12-31 中国科学院近代物理研究所 一种数据全排序方法及系统

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
一种高性能并行计算架构的FPGA实现;钟瑜,吴明钦;《电讯技术》;20190731;第59卷(第7期);全文 *
基于FPGA的硬件排序系统设计;胡二猛,钱承山;《微电子技术》;20151231;第41卷(第12期);全文 *

Also Published As

Publication number Publication date
CN111258535A (zh) 2020-06-09

Similar Documents

Publication Publication Date Title
CN111258535B (zh) 一种用于fpga实现的排序方法
US11783170B2 (en) Spatially sparse neural network accelerator for multi-dimension visual analytics
AU2015231828A1 (en) Parallel decision tree processor architecture
CN106788975B (zh) 基于sm4密码算法的加解密装置
CN112487750B (zh) 一种基于存内计算的卷积加速计算系统及方法
CN112463415B (zh) 基于随机地址的多端口共享内存管理系统及方法
Jeong et al. REACT: Scalable and high-performance regular expression pattern matching accelerator for in-storage processing
CN116992203A (zh) 一种基于fpga的大规模高吞吐量稀疏矩阵向量整数乘法的方法
CN114092338B (zh) 图像缩放快速计算方法
CN117472448B (zh) 一种申威众核处理器从核簇加速并行方法、设备及介质
CN109614145B (zh) 一种处理器核心结构及数据访存方法
CN110597627A (zh) 基于虚拟fpga的数据库运算加速装置及加速方法
CN111552366B (zh) 一种动态延迟唤醒电路及乱序指令发射架构
WO2023155758A1 (zh) 用于数据召回的fpga芯片和数据召回方法
Chacón et al. FM-index on GPU: A cooperative scheme to reduce memory footprint
CN1287314A (zh) 带有具用于一个共用存储器的接口的多个处理器的装置
CN114692079A (zh) 一种gpu批量矩阵乘法加速器及其处理方法
US12001427B2 (en) Systems, methods, and devices for acceleration of merge join operations
US20210303346A1 (en) System and method for queuing commands in a deep learning processor
CN114780151A (zh) 一种基于归并排序算法实现可变规模数量的数据排序系统
CN113448624A (zh) 数据存取方法及装置、系统、ai加速器
CN112817639A (zh) Gpu读写单元通过操作数收集器访问寄存器文件的方法
CN104899008A (zh) 并行处理器中的共享存储结构及方法
CN1238788C (zh) 可处理变长数据的先进先出寄存器队列装置及控制方法
CN1555169A (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