HIGH PERFORMANCE MERGE SORT WITH SCALABLE PARALLELIZATION AND FULL-THROUGHPUT REDUCTION

Information

  • Patent Application
  • 20200159492
  • Publication Number
    20200159492
  • Date Filed
    November 19, 2019
    5 years ago
  • Date Published
    May 21, 2020
    4 years ago
Abstract
Disclosed herein is a novel multi-way merge network, referred to herein as a Hybrid Comparison Look Ahead Merge (HCLAM), which incurs significantly less resource consumption as scaled to handle larger problems. In addition, a parallelization scheme is disclosed, referred to herein as Parallelization by Radix Pre-sorter (PRaP), which enables an increase in streaming throughput of the merge network. Furthermore, high performance reduction scheme is disclosed to achieve full throughput.
Description
BACKGROUND OF THE INVENTION

Multi-way Merge Sort (MMS) is a fundamental operation for a plethora of applications in high performance computing, graphs algorithms, sparse matrix operations, machine learning, scientific research, etc. However, achieving high throughput for MMS binary tree hardware implementation is difficult. Furthermore, when the problem set grows larger, MMS hardware require exponentially more resources for compute and storage, which makes it not easily scalable and parallelizable. Also, full throughput and parallel reduction on the values of the sorted output is required in many cases.


SUMMARY OF THE INVENTION

Disclosed herein is a multi-way merge sort (MMS) implemented in custom hardware that provides higher performance and is more scalable than prior art solutions. This design may be implemented in a custom architectures. The novelty of the MMS hardware can be attributed to the combination of a few techniques, namely advanced comparison, hybrid memory based binary tree, radix pre-sort parallelization, full throughput reducer and parallel shift reduction. This hardware can be used to accelerate matrix/graph operations, such as Sparse Matrix-Vector Multiplication (SpMV).





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram showing the problem of scaling in a binary tree implementation of naive multi-way merge network.



FIG. 2 is a block diagram showing a pipelined multi-way merge binary tree implemented using independent register based FIFOs (IRFM).



FIG. 3 is a block diagram showing a block memory-based multi-way merge network (Scheme-1).



FIG. 4 is a block diagram of advanced comparison based proposed multi-way merge hardware (CLAM).



FIG. 5 shows a hardware diagram of CLAM implementation (excluding pipeline registers) and initialization operation at work cycle tw−1 and tw. The solid and dashed paths show active paths during initialization work cycles tw−1 and tw respectively.



FIG. 6 CLAM hardware diagram (excluding pipeline registers) and initialization operation at work cycle tw+1 and tw+2. The solid and dashed paths show the active paths during initialization work cycles tw+1 and tw+2 respectively.



FIG. 7 is a diagram showing CLAM hardware (including all pipeline registers) and steady state read and address generation operations. The solid and dashed paths show the active paths for read and address generation respectively during tw.



FIG. 8 is a diagram CLAM hardware (including all pipeline registers) and steady state read and write operations. The green and orange paths show the active paths for read at tw−1 and write at tw respectively.



FIG. 9 is a block diagram of a hybrid CLAM (HCLAM) embodiment of the invention.



FIG. 10 shows a diagram of Wide output Multi-way Merge implementation using scalable Parallelization by Radix Pre-sorter (PRaP) and multiple parallel HCLAM cores.



FIG. 11 shows the radix selection for pre-sort in PRaP.



FIG. 12 shows a radix pre-sorter implementation using Bitonic sorter and prefetch buffer, that assumes r(i,j) and r(i,j+x) have the same radix.



FIG. 13 is a diagram, showing load balancing and synchronization by insertion of missing keys in PRaP when the output is dense.



FIG. 14 is a diagram showing a partial SpMV unit (PSU) to conduct step 1 of a two-step algorithm using IMN and independent scratchpad bank access.



FIG. 15 shows insertion-based merge network (IMN) sorting stages.



FIG. 16 is a diagram showing the construction of a P record P-way IMN from smaller 2-way IMNs.



FIG. 17 is a diagram showing a full-throughput reducer design that avoids stalls due to internal pipelines in the adder.



FIG. 18 is a diagram showing a shift-reduction chain to handle collisions among sub-stripes. Illustrated is a 4-way shift-reduction chain.





DETAILED DESCRIPTION

Many important kernels, such as Sparse Matrix dense Vector multiplication (SpMV) and Sparse General Matrix-Matrix multiplication (SpGEMM), require a large parallel and scalable multi-way merge network. Disclosed herein is a novel, multi-way merge network, referred to herein as “Hybrid Comparison Look Ahead Merge” (HCLAM), which incurs significantly less resources as it is scaled to handle larger problems. Also disclosed is a parallelization scheme, referred to herein as “Parallelization by Radix Pre-sorter” (PRaP), which enables an increased streaming throughput of the merge network without prohibitive demand of on-chip memory.


Scalability


From the perspective of hardware implementation and performance, scalability can be viewed from two distinct aspects, which are (1) problem scaling and (2) technology scaling. FIG. 1 shows how problem scaling and technology scaling affect a multi-way merge binary tree implementation. Problem scaling is a phenomenon wherein the input data set becomes larger. For example, when the matrix dimension (i.e. the number of nodes in the graph), becomes larger for SpMV, more lists are required to be merged in the second step of the two-step algorithm. As a result, the required number of sorter cells and FIFOs grows exponentially. Therefore, for practical feasibility, the hardware design should be able to handle a growing matrix size without prohibitively requiring more hardware resources or sacrificing performance.


On the other hand, the design of any algorithm or hardware is expected to take full advantage of new technologies with extended capabilities. For example, 3D stacked high-bandwidth memory (HBM) technology enables extreme off-chip bandwidth. As many sparse matrix kernels should ideally be memory bandwidth bound, accelerators in this domain are expected to properly utilize the extreme bandwidth offered by this new technology. For a single multi-way merge tree hardware, where the maximum output rate is one element per cycle, delivering enough throughput to saturate such high bandwidth is another major challenge. Additionally, maintaining balanced throughput for multiple DRAM channels pose further challenges.


A multi-way merge solution that can practically address both of these scalability issues is unknown. The multi-way merge hardware design disclosed herein address both problem and technology scaling, while being practically feasible for custom hardware platforms, such as Application Specific Integrated Circuits (ASIC) and Field Programmable Gate Arrays (FPGA).


Carnegie Mellon


Problem Scaling


Register FIFO-Based Multi-Way Merge



FIG. 2 depicts a basic hardware binary tree for merging K sorted lists, hence a K-way merge network. The highlighted line represents the activated path in a given clock cycle. For this particular example, K=8. Each element of the lists is a key-value pair, which is referred to as a “record”. In this context, “read” means accessing a certain entry in the FIFO and “dequeue” means updating the counter of the FIFO that is being read. Data “write” and “queue” both mean the same in this context, that is making an entry in the buffer and updating the counter of a FIFO.


The basic building blocks of this tree are sorter cells (comparators) and FIFOs. Each sorter cell compares the keys from the two connected FIFOs and dequeues the record (key-value pair) with the smaller key. To improve clock frequency, the merge tree is further divided into pipelined stages by storing the output of sorter cells in pipeline registers. The total number of stages can be calculated as S=log K+1 and the stage number starts from 0 at leaf level. The most straight-forward hardware implementation uses register-based FIFOs and a total of K−1 sorter cells. For any particular pipeline stage and at any given clock cycle, only one sorter cell remains active in steady state.


A record is dequeued from a FIFO only if the connected sorter in the next stage is active and has the smaller key. Similarly, a record is queued to a FIFO only if it is not entirely full. This implementation is referred to as Independent Register FIFO based Merge (IRFM).


For IRFM, DFIFO is defined as the FIFO depth and Ld as the total number of clock cycles required beginning from the issuance of read requests to a pair of FIFOs to when the output record is ready to be queued in the destination FIFO of next pipeline stage. Additionally, the number of clock cycles to generate the read address, raddri of stage i is defined as La. As raddri is dependent on the output record of stage i+1, a minimum of Ld+La clock cycles are required for a record to travel from one pipeline stage to the next. Hence, maximum throughput of this multi-way merge implementation, RMAX, is 1 element per Ld+La cycles as shown in Eq.(1). Henceforth, the duration of Ld+La clock cycles will be referred to as a working cycle of period (TW).


To maintain RMAX in a steady state, DFIFO has to be a minimum of 2. The reason is that it takes TW time to dequeue a record from any FIFO and it takes another TW time to replenish that FIFO. As a result, for consecutive accesses to any particular FIFO without introducing a bubble, a minimum of two records have to be queued in all FIFOs during initialization. For purposes herein, it is assumed that each FIFO has one read port and one write port independent from each other.


In IRFM, read address generation is trivial as a “not-full” status of any FIFO in stage i+1 can be independently propagated to stage i to generate raddri. For many practical implementations using register FIFOs Ld+La=1 and a throughput of 1 element per cycle is achievable using DFIFO=2. However, it is assumed that the data stream is not interrupted at the leaf level of the binary tree (i.e. the input stage of the pipeline). Due to various technical reasons, in practical implementations it is common to have occasional interruptions in the data stream at the leaf level of the tree. In such cases, it is beneficial to have DFIFO>2 to maintain RMAX.










R

MA





X


=


1


L
d

+

L
a








records





per





clock






cycle
.






(
1
)







Block Memory-Based Multi-Way Merge


As k grows, the logic required for the sorter cells and FIFOs grows exponentially. As hardware resources are limited, this becomes one of the key prohibiting factors in implementing a large multi-way merge network. As a solution to this, implementation design as depicted in FIG. 3 can be used. This implementation is referred to herein as “Scheme-1”. As it is required to read from two FIFOs simultaneously in every stage, the FIFOs in shown in FIG. 2 are logically mapped to set words in two separate memory blocks. All of the even numbered FIFOs are mapped to a memory block (BID=0) and all of the odd numbered FIFOs are mapped to the other memory block (BID=1). Every FIFO in FIG. 3 works as a sorted list that can be considered as the input data for that particular pipeline stage. Stage i handles ki=2(s−i+1) such sorted lists, where S is the total number of stages. Among the lists in stage i, the even numbered ki/2 lists are represented by one memory block (BiID=0) and the odd numbered ki/2 lists are represented by the other memory block (BiID=1).


In any given working cycle tW, two records, namely di,twout0 and di,twout1 are read from the same address of both memory blocks in stage i. However, only the record with the smaller key, di,twmin=min{di,twout0, di,twout1}, is stored in the pipeline register. This record works as the input data di+1,tw+1in to stage i+1 in the next working cycle tw+1. Therefore, for every pipeline stage, Scheme-1 requires 2 reads and 1 write in the pertinent memory blocks. It is important to note that the FIFO that dequeued the record with smaller key in stage i at working cycle tw needs to be replenished at the working cycle tw+1 to maintain steady throughput.


Here, it is assumed that every block memory has one read port and one write port for depiction purpose, which is common for Static Random Access Memory (SRAM). However, this scheme can be generalized, and the fundamental principles do not depend on the number ports of the memory blocks.


One advantage of Scheme-1 is that now only log k sorter cells are required instead of K−1. Secondly, a single SRAM block can be used instead of multiple separate register based FIFOs. This significantly reduces the silicon real estate required for buffer storage needed in a multi-way merge network as SRAM cells (8 transistors) are much smaller than registers (19 transistors). However, as described below, there are a number of potential issues that can render Scheme-1 to be inefficient.


Performance: The block memory in each stage, as depicted in FIG. 3, can be conceptually conceived as a collection of several logical FIFOs sharing a common port for data input and output. Due to this shared port, these logical FIFOs cannot independently enact themselves along the relevant branch of the multi-way merge binary tree. As a result, additional control logic is required. This control logic can potentially become the critical path and reduce throughput by introducing cycle delays (bubbles) in the pipeline.


Scalability: With increasing k, the FIFO buffer requirement grows exponentially for all multi-way merge binary trees. To make it worse, the depth of each logical FIFO in Scheme-1 is required to be increased to partially compensate for the latency and additional control logic delay described above. Therefore, efficient on-chip memory management is imperative to scale multi-way merge network.


Latency: Due to monolithic decoder and SRAM technology, the read and write latency of on-chip block memory is generally much higher than of register based FIFOs. This latency significantly reduces the performance of Scheme-1 based multi-way merge implementations.


Comparison Look Ahead Merge (CLAM)


Disclosed herein is a first embodiment of a multi-way merge implementation scheme, referred to as Comparison Look Ahead Merge (CLAM). CLAM provides better performance (records per cycle) through an efficient address generation scheme and is more scalable due to less demand for buffer storage. Further disclosed herein is a second embodiment of a method, referred to as Hybrid Comparison Look Ahead Merge (HCLAM), to hide the block SRAM latency by pragmatically using both SRAM and registers as merge tree buffers. Both CLAM and HCLAM implementations are novel and no similar methods are found in the prior art.


Before describing the embodiments, the following terminologies are defined for clarity of explanations.


In FIG. 3, FIFO (i,j) sequentially feeds the records from sorted list l(i,j) to its following stages and, as such, l(i,j) can be thought of as the jth input list with respect to stage i, where j−0, . . . , ki. The leaf level FIFOs at 0th stage feed the original input data set (K lists) to the entire binary tree.


The frontier record of list l(i,j) is represented as r(i,j). The frontier record of a list is the top most record that hasn't been dequeued from the list yet.


All sorted lists pertaining to any pipeline stage are numbered starting with 0. Comparison between the frontier records of two consecutive lists l(i,j) and l(i,j+1) will always imply that j is an even number. The notation min{r(i,j),r(i,j+1)} indicates the record with the smaller key between the frontier records of two consecutive lists starting with j at stage i. The notation max{r(i,j),r(i,j+1)} indicates the record having the larger key with the rest being the same.


The main idea of CLAM comes from the observation that in any stage of Scheme-1, records are read from the FIFOs and the read address in the next cycle is generated from the comparison results of these records. This sequential dependence of the address on data read in previous cycle is inevitable as this is the fundamental operation of multi-way merge. However, without violating this data dependency, the following operations can be conducted. First, instead of comparing the keys of records when they are dequeued from the FIFOs, the keys can be compared while being queued to the FIFOs. As consecutive lists are compared before they are actually needed, the results of this operation referred to as “comparison look ahead”. Second, this comparison information can be stored using a single bit, namely ‘tag’ (g), and used later to generate an address while the pertinent record is actually dequeued.


These two concepts represent the core of CLAM. The main benefit of CLAM is that it is not necessary to wait for the reading of records from block memory and the comparison to be completed before beginning to generate the address. As the comparison result is already available (i.e., the tag g is pre-computed) the next cycle read address can begin to be generated parallel with the initiation of the read of the current cycle. Therefore, the working cycle duration TW in CLAM is max(La,Ld) unlike the case of Scheme-1 (i.e. La+Ld).



FIG. 4 is a block diagram of a simplified and conceptual diagram of CLAM that is derived from the implementation of Scheme-1. Instead of directly storing records from the sorted lists, the memory blocks store the output of a comparator. The input to the comparator is the frontier of two consecutive lists. Block Bmin stores the records with smaller keys and block Bmax stores the records with larger keys. Therefore, when a record is requested from stage i to stage i+1, it can be directly dequeued from Bmin without any further comparison.



FIG. 5 shows a hardware diagram of CLAM implementation only depicting the connections related to stage i. For better clarity, the pipeline registers are not shown. What follows is an explanation of the important aspects of CLAM implementation and operation in detail.


Data and Address Storage


As depicted in FIG. 5 and FIG. 6, the data buffer requirements in CLAM are different than those required for Scheme-1. It is understandable that only one record from Bmin needs to be transferred to the next stage in a work cycle. As such, to serve consecutive accesses into the same address without introducing a bubble, logical FIFOs in are required. On the other hand, logical FIFOs are not required in Bmax as its records are not directly transferred to the next stage. A record from Bmax only takes part in the computation for look ahead comparison when a record is queued in Bmin in any given work cycle. Therefore, Bmax has single entry words instead of logical FIFOs. It was mentioned earlier that stage i handles ki−2(s−i−1) input sorted lists, where S is the total number of stages. Hence, Bmin is a memory block with ki/2 logical FIFOs and Bmax is a memory block with k1/2 words. If the depth of each logical FIFO is DFIFO, then Bmin has in total (DFIFO×k1/2) words.


Another important difference between CLAM and Scheme-1 is that in every work cycle there are two writes in a stage instead of one. In both CLAM and Scheme-1, one record moves from one pipeline stage to the next in a work cycle. In Scheme-1, the incoming record is queued to one of the memory blocks to replenish one logical FIFO in one of the memory blocks. Similarly, in CLAM, after advanced (look ahead) comparison with the incoming record we need to queue a min{r(i,j),r(i,j+1)} in Bimin to replenish a FIFO. Additionally, it is also necessary to write max{r(i,j),r(i,j+1)} in Bimax to conduct the advanced comparison in the future. Thus, in CLAM there are two reads and two writes of records in every stage at each work cycle.


CLAM also has a read queue to store the read address. This read queue serves the same purpose of storing read request addresses from the following stage and helps to avoid bubbles. A read queue in stage i−1 provides the read address raddri−1 for Bi−1min and Bimax. Bimax handles half of the number of lists then does and the LSB of raddri−1 is excluded before using it as read address of Bimax. Therefore, the read address of Bimax is defined as rBXi=raddri−1, excluding LSB.


Tag Array


Tag (g) is a single bit that stores the result of advanced (look ahead) comparison. An additional buffer is required in CLAM to store the tags that is named as “Tag Array”. Only a single tag bit is required per FIFO of Bmin. Hence, tag array in stage i has ki/2 bits only. As tag array memory requirement is trivial and it can be implemented using registers instead of SRAM for fast access. In every work cycle, one tag bit is updated and utilized to generate address per stage using the following rules.


Tag update rule: Assume r(i,j) and r(i,j+1) are the inputs to the comparator of stage i. If r(i,j)=max{r(i,j), r(i,j+1)}, the tag bit giz is updated to ‘1’. Otherwise, if r(i,j+1)=max{r(i,j), r(i,j+1)}, the tag bit gf is updated to ‘0’. Here z=j/2 and j is always an even number in this context. The value of z ranges from 0 to (ki/2−1).


Tag usage rule: Tag gf is used to generate the LSB of the read request address whenever a r(i,j) is dequeued from the Zth FIFO of Bmin. This request is stored in the read queue of stage (i−1). The entire request address is formed as {z, giz}, where z=raddri is the read address for Bimin at current working cycle.


Initializing Operation



FIG. 5 and FIG. 6 depict three pipeline stages, where stage (i−1) is fully initialized, stage i is being initialized and stage (i+1) is totally un-initialized. Here, only the connections related to stage i are shown for ease of comprehension. In FIG. 5, the blue and black lines are the active paths during initialization work cycles tw−1 and tw respectively. Similarly, in FIG. 6, the solid and dashed paths show the active paths during initialization work cycles tw+1tw+2 respectively. The initialization process is now described step by step.

    • 1. At the very beginning all the entries in Bmax and Bmin are considered empty. However, all the bits in the tag array are initialized with ‘0’s. FIG. 5 shows the state of all memories at work cycle tw−1.
    • 2. Assume that at a given work cycle tw−1, the read queue in stage i serves as read address raddri,tw−i. Hence, a record from the last FIFO of Bimin is requested. As this FIFO is empty, a null will be delivered. At the same time, the initial value of gi1=0 will be read from the tag array and used to form the read request address for the read queue in previous stage (i−1). The tag bit serves as the LSB and the read address in current work cycle tw−1 serves as the rest. Hence, a read request of address {raddri,tx−1, gi}=(10)b=2d is sent to the previous stage (i−1) to be logged in its read queue at the end of work cycle tw−1.
    • 3. At the beginning of work cycle tw, read queue of stage (i−1) serves the address raddri−1,tw={raddri,tw−1, gi1}=2d. Hence, the record in the 2nd FIFO min{r(i−1,4), r(i−1,5)} is read from Bi−1min and passed to the next stage i as the incoming record r(i,2) in work cycle tw. At the same time, raddri−1,tw (excluding LSB) also works the read address (rBXi,tw) for in tw. Hence, a null value from the last entry of Bimax is read.
    • 4. At tw, the comparator in stage i compares r(i,2) with null value. We define min{r(i,2),null}=null and max{r(i,2),null}=r(i,2). Hence, at the end of work cycle tw, r(i,2) is written to Bimax and null value is written to Bimin. It should be noted that write address of both Bimax and Bimin in any work cycle is just a delayed version of the read address of Bimax in previous work cycle excluding the LSB. Therefore, write address waddri,tw−i=rBXi,tw=raddri−1,tw (excluding LSB)=1d.
    • 5. While data is written in the block memories of stage i, the tag bit at address waddri,tw+1 is also updated. In this case, waddri,tw+i=1d. Hence, gi1 is updated to ‘1’ following the tag bit update rule state above at the beginning of (tw+1).
    • 6. FIG. 6 shows the state of all memories at work cycle (t+1). As the last FIFO in Bimin is still empty, the read queue in stage i will again serve a read address raddri,tw+1=1d. Operations as described above in steps 2-5 will repeat for work cycle (tw+1) and (tw+2). However, this time the tag bit read at (tw+1) is gi1=1. Hence, the 3rd record from B1−1min and r(i,2) from Bimax is read in (tw+2). At the beginning of work cycle (tw+3), max{r(i,2),r(i,3)} is written to Bimax and min{r(i,2),r(i,3)} is written to Bimin. The tag bit gi1 is also updated and, thus, stage i is completely initialized after (tw+2).


Steady State Operation



FIG. 7 and FIG. 8 depict detailed diagram of CLAM operation in steady state including all the pipeline registers and all connections. All the memory buffers and tag array are in steady state. Pipeline registers are used at the same depth that as for Scheme-1 in FIG. 5.


In FIG. 7, the solid and dashed paths show the active connections during data read and address generation respectively at tw. Registers f1, f2 and f3 participate in the data read process and f4 and f5 participate in the address generation process. The numbers mentioned in the registers represent the clock cycle within a work cycle that triggers them (at rising edge). At the rising edge of clock cycle 1, f1 latches the read address raddri, tw from the read queue. Hence, Bimin and Bi+1max is read during clock cycle 1. At the rising edge of clock cycle 2, f2 and f3 latch these read data and advanced comparison of the keys are conducted during this clock cycle. Thus, for data read and look ahead comparison the number of required clock cycles Ld is 2.


During clock cycle 1 raddri,tw is also used to read the previously computed comparison result gi,twout from the tag array. At the rising edge of clock cycle 1 f4 also latches advanced comparison result gi,twin that is latched into the tag array at the rising edge clock cycle 2 at address waddri, tw=rBXi,tw−1. During clock cycle 1, if raddri,tw happens to be the same as wad t, then gint, is used as gi,twout instead of what is actually read from the tag array. This is because the tag value pertaining to the latest record queued to the FIFOs in Bimin must be used for the read request address generation. In any case, at the rising edge of clock cycle 2, request address {raddri,tw,gi,twout} is stored in the read queue of stage (i−1) through register f5. Hence, the overall address generation process also takes 2 clock cycles, i.e. La=2.


For efficient implementation of CLAM, data write must be overlapped with read or address generation and finished within min{Ld,La} clock cycles so that no extra time is spent for write. In FIG. 8, the active paths during data write are depicted at tw, (solid paths) besides the ones during data read at tw−1 (dashed paths). In fact, the data write process only takes one cycle as the write address generation is trivial and already available from the data read operation in work cycle tw−1. At the rising edge of clock cycle 1 in tw−1,raddri−1,tw−1 is latched by f6. This address is used to read records from and Bi−1min and Bimax, which are latched by f7 and f8 at the rising edge of clock cycle 2 in tw−1. Hence, at the rising edge of clock cycle 1 in tw both the output records after comparison is latched by f5 and f4. These stored records at f5 and f4 are written to Bimax and Brin memory blocks during the first clock cycle of tw, which is overlapped with the data read from these memory blocks. For both Bimax and Bimin write address is waddri,tw=rBxi,tw−1 which is available from the previous work cycle tw−1.


CLAM Performance: Because the data read and address generation is parallelly conducted in CLAM, duration of a work cycle Tw can be derived by max{Ld,La}. As both Ld and La are 2, the duration of Tw is also 2 cycles. Unlike in Eq(1), the maximum throughput of CLAM can be calculated as Eq(2). Due to the overlap of data read and address generation RCLAMmax is two times faster than RScheme−1max, which is the highest throughput possible by block memory-based multi-way merge implementations.










R
CLAM

ma





x


=


1

max


{


L
a

,

L
d

,

}



=


1
2






records





per





clock





cycle






(
2
)







CLAM Scalability: Scarcity in fast on-chip memory is one of main reasons that multi-way merge implementations cannot scale. We have seen that in Scheme-1, both the memory blocks in a pipeline stage comprise of logical FIFOs. However, in CLAM, only one of the memory blocks comprise logical FIFOs. Hence, if the FIFO depth increases only by 50% of the memories in CLAM increase, whereas in Scheme-1b 100% of the memories increase in size. Furthermore, as CLAM work cycle is half of the work cycle for Scheme-1, relatively less FIFO depth is required in CLAM to avoid bubbles. The additional resources that CLAM needs is the storage for tag array. However, only single bit per logical FIFO is required, which is trivial.


Hybrid CLAM (HCLAM)


One of the main drawbacks of using SRAM blocks instead of registers for multi-way merge tree is that SRAM read latency is significantly larger. CLAM utilized a deeply pipelined design to improve clock frequency. However, the clock period is bounded by the SRAM block read latency. Furthermore, the throughput of deeply pipelined CLAM's is one element in two cycles, whereas register FIFO based merge can provide a throughput of one element per cycle. Hybrid CLAM is a pragmatic way of utilizing both SRAM and register based implementation.



FIG. 9 elaborates the hardware implementation of HCLAM. Here, the large, in terms of memory usage, stages of the multi-way merge network are implemented using SRAM memory based CLAM. The last few stages, i.e. those close to the final output, are implemented using independent register FIFO based merge tree (i.e. IRFM, as shown in FIG. 2). This is a hybrid implementation because of the mix between two different types of multi-way merge schemes. Previously, IRFM was discarded as a scalable multi-way merge network because it is not feasible to implement for large values of K due its high resource requirement of memory and logic. However, the last few stages of IRFM require only a trivial number of buffers and sorter cells. As such, for any multi-way merge binary tree implementing the last few (e.g. 3 or 4) stages using IRFM doesn't have any considerable effect on the scalability of overall implementation. However, integrating these few stages with the CLAM network as shown in FIG. 9 helps to hide the SRAM latency of CLAM. The idea is that multiple CLAM networks will queue their output records in multiple asynchronous FIFOs at their peak throughput. At the same time, these asynchronous FIFOs will work as the input lists for a small IRFM network that has higher throughput. If the absolute rates of input and output of these asynchronous FIFOs are matched, then the overall HCLAM implementation will achieve the higher throughput of IRFM, while having the better scalability of CLAM.


The two different multi-way merge schemes in HCLAM are implemented using two independent clocks as shown in FIG. 9. The clock periods of clkCLAM and clkIRFM are defined as TCLAM and TIRFM. In practical implementations, clkCLAM is slower than c/k/RFm as the SRAM read latency falls in the critical path of CLAM, (i.e. TCLAM>TIRFm). Furthermore, the maximum throughput of CLAM KnLaAxm is 1/2TCLAM, which is less than the maximum throughput of the register FIFO based merge RIRFMmax=1/TIRFM. The goal of HCLAM is to provide the same throughput as RIRFMmax for the entire multi-way merge network. It is easily achievable by integrating multiple CLAM networks with an IRFM network at the proper ratio (RatioHCLAM). Eq(3) provides a formula to calculate this ratio.










Ratio
HCLAM

=



R
IRFM

ma





x



R
CLAM

ma





x



=


2


T
CLAM



T
IRFM







(
3
)







For an ASIC implementation clkIRFM is almost twice as fast as clkCLAM. In that case, RatioHCLAM is 4 as computed by Eq(3). Furthermore, the number of stages required for IRFM can be calculated as log2(RatioHCLAM)+1=3.


It is also important to have enough depth in the RatioHCLAM number of asynchronous FIFOs that interfaces the two different networks. If the data set is not heavily skewed towards any particular set of input lists, a FIFO depth of 8 to 32 works reasonably well. Even if data is heavily skewed, the depth can be increased without considerably affecting overall scalability as RatioHCLAM is expected to be small (on the order of 2 to 8).


Parallel Multi-Way Merge


Even though HCLAM itself increases the performance of a single multi-way merge network by almost 3 times, it still not enough to saturate the system streaming bandwidth properly. Therefore, a parallel implementation of the merge network that can output multiple records to match the available streaming bandwidth is needed. A scalable parallelization method that can effectively address technology scaling is disclosed and referred to herein as Parallelization by Radix Pre-sorter (PRaP).


Parallelization by Radix Pre-Sorter (PRaP)


From the discussion above it is apparent that a parallelization scheme is need that doesn't require increasing prefetch buffer with more parallel multi-way merge networks. PRaP is a solution to this problem, which is depicted in FIG. 10. The idea is to implement p independent multi-way merge networks where each will only work on records with certain radix within the keys. For that purpose, each record streamed from DRAM is passed through a radix based pre-sorter and directed to its destination merge network. Each such merge network is denoted as a Merge Core (MC) that is implemented using HCLAM. q is defined as the number of LSBs from the key of a record that is used as the radix for pre-sorting as shown in FIG. 11. The number of MCs is p=2q and, thus, a multi-way merge network with total output width of p records can be achieved. The main benefit of PRaP is that, irrespective of p, the on-chip prefetch buffer size is Kdpage, which is only 2MB given the example in previous section. Because p can be incremented without requiring more on-chip storage, PRaP is significantly scalable and effective in addressing technology scaling. It is important to note that PRaP method of parallelization only works when it is guaranteed that the sorted output list is a dense vector, as in the case for output vector y in SpMV.


Radix Pre-Sorter Implementation


Without any loss of generality, assume that the DRAM interface width is also p records. Whenever the ith list l(i) is streamed from DRAM, records r(i,j) to r(i,j+1) is transferred in a single clock cycle as a part of the prefetched data. These p records are then passed through pipelined radix based pre-sorter as shown in FIG. 12. The pre-sorter is implemented using a Bitonic sorting network as p output per cycle is required to match the input rate. FIG. 12 depicts the Bitonic network in simplistic manner. The horizontal lines show the data path of the record. The downward and upward arrows represent comparison and swap operation in the ascending and descending order respectively. It is important to note that only q bits of the keys take part in the comparison operation of the pre-sorter. The logic resource requirement of PRaP pre-sorter is significantly less than what is required for a one with full key comparison.


During the pre-sort, it is mandatory to maintain the original sequence of the records that possess the same radix. For example, as shown in FIG. 12, if r(i,j) and r(i,j+x) and both have the same radix bits then r(i,j) should precede r (i,j+x). This is imperative because for any given merge core the input records of any list must be sorted with respect to the rest of the bits other than the radix within key. After pre-sorting, the outputs are stored in the prefetch buffer at the allocated location for list li. The prefetch buffer allocates dpage size storage for each list. Internally within the buffer for each list, the radix sorted records are kept in separate slots for the ease of feeding to the appropriate MC. For example, if the radix of record r(i,j), ead(i,j) is 100b then record r(i,j) is stored in the page buffer only for consumption of MC4.


Load Balancing and Synchronization


It is possible for the incoming lists to have keys that are imbalanced in terms of the radices. In such case, the data are unevenly distributed among the MCs and potential load imbalance will occur. More importantly, as the independent MCs work only on a particular radix, further sorting and synchronization among the output of cores should have been required to generate a single sorted final output. Both of these issues can be effectively resolved from the observation that the final output list is a dense vector. It is guaranteed that each MC will sequentially deliver records with monotonously increasing keys (assuming sort in ascending order). Additionally, is also mandatory that each possible key, which is the row index of the sparse intermediate vector in Two-Step SpMV, is present in the resultant dense vector. For example, as shown in FIG. 13, assume that the input data set with radix (010)b=2 doesn't have any record with key 10. For that reason, the MC2 sequentially delivers records {2,va2} (key 2 and value va2) and {18,va18}. As a result, an expected record with key 10 is missing at the output stream of MC2. To handle this scenario, missing key check logic is included in the MC design. Whenever a missing key is detected at the output, that key is artificially injected in between the original outputs along with a value of ‘0’ and the following records are delayed. Thus, for the given example, an artificial record {10,0} is injected after {2,va2} and {18,va18} and {26,va26} are delayed.


The insertion of missing keys, necessitated by the dense output vector, solves both the load imbalance and synchronization problem. First, even though data are unevenly distributed among the cores, at the output each MC produces same number of records at similar rate. The effect of load imbalance is practically hidden even if it occurs. Second, output from the p cores, y(cp+0) to y(cp+p−1), can be independently queued in a store queue and synchronously streamed out (dequeued) to DRAM. The records y(cp+0) to y(cp+p 1) are consecutive elements of the dense output vector. Furthermore, records dequeued at cycle c and (c+1) are also consecutive segments of the dense vector. Thus, more sorting logic to synchronize the outputs is not required from p independent multi-way merge cores. Therefore, in the parallelization method PRaP the design can be scaled to multiple cores without increasing on-chip buffer requirements and will achieve the required throughput to match the streaming main memory bandwidth. Only q=4 bit radix pre-sorting (i.e., 24=16) cores, is enough to saturate the extreme HBM bandwidth that is in the order of hundreds of GBs.


Up to this point, a scalable multi-way merge merge scheme that can effectively and practically handle large problem size (thousands of lists) at extremely high throughput (hundreds of GBs or several TBs) has been disclosed. The entire method can be termed as HCLAM with PRaP parallelization. HCLAM mainly handles problem scaling and PRaP parallelization handles technology scaling. The method is scalable because it doesn't prohibitively require more on-chip memory or logic as the problem size grows. Because of PRaP, the throughput can also be increased by incrementing the number of merge cores without increasing on-chip memory, which is the most critical resource for scaling.


Reductions for High Performance Merge Operation


Reductions (i.e. accumulating values for more than one record if their indices match) are very common and an integral operation in many multi-way merge implementations. Reductions also need to be done at full throughput to match the performance of high throughput merge. However, latency in floating point adders create challenge in maintaining full throughput during reductions. There are various scenarios where full throughput reductions are necessary.


For example, for the SpMV operation, P sets of floating point (FP) multiplier and adder chains parallelly work on separate sub-stripes of AK and sub-segments of xk, as shown in FIG. 14. Thus, P sorted lists are generated at the output of P multipliers. Every sorted list needs to be reduced at full throughput by a reducer. Moreover, at the end of reducing P sorted lists independently, they need to be merged them into one final vector vK (resultant sorted list). For this merge operation, an Insertion based Merge Network (IMN), as depicted in FIG. 15, may be used.


A P-way IMN is capable of delivering P records (i.e. key-value pairs) per cycle. As shown in FIG. 15, the main idea of sorting by insertion is to compare keys of P sorted incoming records from a list parallelly with another key of a previously stored record in a single sorter pipeline stage. This stored record is inserted in the appropriate position among the incoming records and a new set of (P+1) sorted records is constructed. The last among these (P+1) records replaces the stored record in the following cycle. Such (P−1) sorter stages can be pipelined to construct a P record 2-way IMN. At the first stage, P incoming sorted records are sourced from one of two input lists and l0 and l1. The top records of l0 and l1 are compared and the list with the smaller key (assuming ascending order) delivers the P sorted incoming records for the IMN at any given cycle. All stored records at each pipeline stage are initialized with zero. FIG. 16 depicts how several smaller 2-way IMNs can be connected together to build a larger IMN with more ways. The coupler consists of FIFOs and simply appends stream of records to double the stream width. IMN is not easily scalable due to high resource usage as P increments. However, for the purpose of PSU, with small P it is possible to maintain high throughput to utilize 3D DRAM streaming bandwidth.


IMN-based schemes are preferred for PSU rather than the shared scratchpad-based one as it provides more computational efficiency with same level of hardware complexity.


Full-Throughput Reducer


One of the important aspects of the above computation is the reducer. Accumulation or reduction is required for collisions (i.e. when row-indices of two consecutive records match). However, a pipelined adder cannot handle more than one collision without introducing stalls in the entire computational pipeline. These stalls are due to internal pipelines of the adder. F is denoted as the number of internal pipelines of an adder. An entire addition, which takes F cycles, has to be completed before start resolving the next if another collision is found for the same row index. To overcome this, a chain of log2F adders can be used, along with another final adder, as shown in FIG. 17, that can resolve all collisions for any given row index without introducing any stalls. This entire scheme ensures full throughput during merge and consecutive reduction operation. The internal logic of each type of adder is also elaborated in FIG. 17. An adder intakes one record per cycle and compares the row index (row) of the current record, record(t), with the row of record(t−1). Here t represents the sequence of records as they appear at the input of the adder. If row(t) and row(t−1) match, the values are added and a new record, sum(t), is delivered that has a key row(t) and a value val(t)+val(t−1). If no collision is found, record(t−1) is delivered and record(t) is temporarily stored to check collision with record(t+1). In the case of the final adder in the reducer, there will be F cycles delay between two consecutive records. The result sum is ready for the feedback path to be accumulated with the incoming record in case the indices match. Here, sum(t) represents the accumulated result for all the collisions comprising record(t). When no more collisions are found between the incoming record and sum, the output is then released from the Reducer.


Full Throughput Shift-Reduction Chain


While the Reducer resolves all collisions within a sub-stripe of the matrix, there can still be collisions among the P sub-stripes. Therefore, the sorted outputs are required to be checked for collisions and resolved when needed. To achieve this in a pipelined manner, a P-way shift-reduction chain maybe used as depicted in FIG. 18. The main idea is to sequentially check two neighboring records for collision. This process starts from one end of the sorted outputs of the IMN. If starting from bottom, when the indices of the records match the upper output stream delivers the accumulated result and the lower output stream delivers an artificial 0 (or null) value. When this process continues to the next pipeline stage of the chain, the next two recorded are checked for collision as shown in FIG. 18. This process is referred to as shift-reduction, as in every stage of the chain selection of the records shifts by one. Thus, at the end of shift-reduction chain, all collisions are resolved for P-wide sorted output list. For a P-way shift-reduction chain, P−1 pipeline stages are required.

Claims
  • 1. A computer-implemented method for implementing a comparison look-ahead merge network, comprising: For each stage in the network: dequeuing a read address from a read queue at a previous stage of the network;reading a record from a first block of memory indexed by the read address;comparing a record read from the first block of memory and an input record from the previous stage;storing a tag bit in a tag array; storing the max of the comparison in the first memory block;storing the min of the comparison in a FIFO;storing a request address in the read queue of the previous stage, the LSB of the request address being a tag from the tag array; anddequeuing a record from the FIFO to be used as an input to the next stage.
  • 2. The method of claim 1, the tag bit indicating which between the record read from the first block of memory and the input record from the previous stage has been stored in the FIFO.
  • 3. The method of claim 2, the tag bit being used to select one of two FIFO's from the previous stage.
  • 4. The method of claim 1, the dequeued read address from the previous stage of the network also being used to read the input record from the previous stage from a FIFO in the previous stage.
  • 5. The method of claim 1, the record from the first block of memory and the input record from the previous stage being read during a first clock cycle.
  • 6. The method of claim 1, the record from the first block of memory and the input record from the previous stage being compared during a second clock cycle.
  • 7. The method of claim 1, a tag bit from a previous compare being read from the tag array during a first clock cycle.
  • 8. The method of claim 1, the request address being stored in the read queue of the previous stage during a second clock cycle.
  • 9. A multi-stage comparison look-ahead merge network, comprising, for each stage in the network: a first memory block containing one or more records;a second memory block containing one or more FIFO's.a comparator, comparing a record from the first memory block with an input record from a previous stage and storing the min of the comparison in a FIFO in the second block of memory and the max of the comparison in the first block of memory;a tag array comprising a plurality of tag bits, each tag bot corresponding to a FIFO in the second memory block, the tag bit for each FIFO indicating which of the record from the first memory block or the input record from a previous stage has been stored in the FIFO; anda read queue containing read addresses, the read addresses indicating a FIFO in the second memory block from which an input record for a next stage in the network should be read and also indicating a record in the next stage of the network that should be compared to the input record for the next stage in the network.
  • 10. A hybrid network comprising: an independent register FIFO based merge tree;one or more multi-stage comparison look-ahead merge networks of claim 9; andan asynchronous FIFO coupled to the output of each multi-stage comparison look-ahead merge network, the asynchronous FIFO using a clock of the multi-stage comparison look-ahead merge network for writes to the FIFO and a clock of the independent register FIFO based merge tree for reads from the FIFO, each asynchronous FIFO being an input to the independent register FIFO based merge tree.
  • 11. The network of claim 10 wherein the clock of the multi-stage comparison look-ahead merge network is slower than the clock of the independent register FIFO based merge tree.
  • 12. The network of claim 10, the ratio of multi-stage comparison look-ahead merge network to the independent register FIFO based merge tree indicated by the formula:
  • 13. A parallel multi-way merge network comprising: a radix-based pre-sorter for sorting records based on a radix with the key of each record; anda plurality of multi-way merge networks, each multi-way merge network only operating on records having a certain radix,wherein the radix pre-sorter sorts each input record for input to a multi-way merge network operating on records having a radix matching the input record.
  • 14. The network of claim 13 further comprising: a plurality of pre-fetch buffers, each pre-fetch buffer associated with a multi-way merge network, each pre-fetch buffer accepting inputs for the associated multi-way merge network from the radix-based pre-sorter.
  • 15. The network of claim 13 wherein the radix is a q number of least significant bits of the key of each record and further wherein the number of multi-way merge networks is 2q.
  • 16. The network of claim 13 wherein each multi-way merge network is a hybrid network of claim 10.
  • 17. The network of claim 13 wherein each hybrid network further comprises missing key check logic that, when no input data set with a radix matching the operating radix of the hybrid network exists, injects an artificial record having a the missing key and having a value of 0 between two original outputs, and delays one or more following records.
  • 18. A full-throughput reducer comprising: a multiplier;a series of log2F adders; anda final adder;wherein F is a number of internal pipelines in each adder;wherein each adder in the series of adders: takes an input record and determines if a collision exists between the input record and a previous input record, a collision being indicated by a match of the row indices of the input record and the previous record;if a collision is indicated, outputting a new record having as a key the row index and having as a value the sum of the values of the input record and the previous record;if no collision is indicated, outputting the previous record and holding the input record for comparison with the next record; andwherein the final adder: accumulates a sum with an incoming record via a feedback path, where the sum represents the accumulated result for all records having matching indices; andoutputs the sum when no further matches are found between the input record and the sum.
  • 19. A full-throughput shift reduction chain comprising a plurality of pipelined stages, wherein the pipelined stages: sequentially check two adjacent records for collision, a collision being indicated when the row indices of the two records match;if a collision is indicated, deliver a null value at a first output and deliver a sum of the records at a second output, the second output being used as an input for a next pipeline stage.
  • 20. The full-throughput shift reduction chain of claim 19 wherein P-1 pipelined stages are required for a P-wide sorted list.
RELATED APPLICATIONS

This application claims the benefit of U.S. Provisional Patent Application No. 62/917,113 filed Nov. 19, 2018, the contents of which are incorporated herein by reference in their entirety.

GOVERNMENT INTEREST

This invention was made with government support under contracts HR0011-13-2-0007 and HR0011-16-C-0038 awarded by the Defense Advanced Research Projects Agency (DARPA), and contract N66001-12-C-2008 awarded by the Intelligence Advanced Research Projects Activity (IARPA). The government has certain rights in the invention.

Provisional Applications (1)
Number Date Country
62917113 Nov 2018 US