Collective communication system and methods

Information

  • Patent Grant
  • 12177039
  • Patent Number
    12,177,039
  • Date Filed
    Sunday, November 19, 2023
    a year ago
  • Date Issued
    Tuesday, December 24, 2024
    8 days ago
Abstract
A method includes providing a plurality of processes interconnected by a network, each of the plurality of processes being configured to hold a block of data destined for others of the plurality of processes. A set of data for all-to-all data exchange is received from one or more of the processes. The set of data is configured as a plurality of blocks of data in a matrix as matrix data, the matrix being distributed among the plurality of processes. The matrix data is transposed by changing the position of selected blocks of data of the plurality of blocks of data relative to the other blocks of data of the plurality of the blocks of data, without changing the structure of each of the blocks of data. The transposed matrix data is over the network and is then received, repacked, and conveyed to destination processes.
Description
FIELD OF THE INVENTION

The present invention, in exemplary embodiments thereof, relates to collective communication systems and methods, and particularly but not exclusively to message passing operations, and also particularly but not exclusively to all-to-all operations.


SUMMARY OF THE INVENTION

The present invention, in certain embodiments thereof, seeks to provide improved systems and methods for collective communication, and in particular, but not only, for message passing operations, including all-to-all operations.


There is thus provided in accordance with an exemplary embodiment of the present invention a method including providing a plurality of processes, each of the plurality of process being configured to hold a block of data destined for others of the plurality of processes, providing at least one instance of data repacking circuitry including receiving circuitry configured to receive at least one block of data from at least one source process of the plurality of processes, repacking circuitry configured to repack received data in accordance with at least one destination process of the plurality of processes, and sending circuitry configured to send the repacked data to the at least one destination process of the plurality of processes, receiving a set of data for all-to-all data exchange, the set of data being configured as a matrix, the matrix being distributed among the plurality of processes, and transposing the data by each of the plurality of processes sending matrix data from the process to the repacking circuitry, and the repacking circuitry receiving, repacking, and sending the resulting matrix data to destination processes.


Further in accordance with an exemplary embodiment of the present invention the method also includes providing a control tree configured to control the plurality of processes and the repacking circuitry.


Still further in accordance with an exemplary embodiment of the present invention the control tree is further configured to receive registration messages from each of the plurality of processes, mark a given subgroup of the plurality of processes as ready for operation when registration messages have been received from all members of the given subgroup, when a given subgroup which is a source subgroup and a corresponding subgroup which is a destination subgroup are ready for operation, pair the given source subgroup and the given destination subgroup and assign the given source subgroup and the given destination subgroup to an instance of repacking circuitry, and notify each the source subgroup and each the destination subgroup when operations relating to each the source subgroup and each the destination subgroup have completed.


Additionally in accordance with an exemplary embodiment of the present invention the control tree is configured, in addition to pairing the given source subgroup and the given destination subgroup, to assign the given source subgroup and the given destination subgroup to an instance of data repacking circuitry.


Moreover in accordance with an exemplary embodiment of the present invention the method also includes assigning circuitry other than the control tree, the assigning circuitry being configured to assign the given source subgroup and the given destination subgroup to an instance of data repacking circuitry.


Further in accordance with an exemplary embodiment of the present invention the control tree includes a reduction tree.


There is also provided in accordance with another exemplary embodiment of the present invention apparatus including receiving circuitry configured to receive at least one block of data from at least one source process of a plurality of processes, each of the plurality of process being configured to hold a block of data destined for others of the plurality of processes, at least one instance of data repacking circuitry configured to repack received data in accordance with at least one destination process of the plurality of processes, and sending circuitry configured to send the repacked data to the at least one destination process of the plurality of processes, the apparatus being configured to receive a set of data for all-to-all data exchange, the set of data being configured as a matrix, the matrix being distributed among the plurality of processes, and the apparatus being further configured to transpose the data by receiving, from each of the plurality of processes, matrix data from the process at the repacking circuitry, and the data repacking circuitry receiving, repacking, and sending the resulting matrix data to destination processes.


Further in accordance with an exemplary embodiment of the present invention the apparatus also includes a control tree configured to control the plurality of processes and the repacking circuitry.


Still further in accordance with an exemplary embodiment of the present invention the control tree is further configured to receive registration messages from each of the plurality of processes, mark a given subgroup of the plurality of processes as ready for operation when registration messages have been received from all members of the given subgroup, when a given subgroup which is a source subgroup and a corresponding subgroup which is a destination subgroup are ready for operation, pair the given source subgroup and the given destination subgroup and assign the given source subgroup and the given destination subgroup to an instance of data repacking circuitry, and notify each the source subgroup and each the destination subgroup when operations relating to each source subgroup and each destination subgroup have completed.


Additionally in accordance with an exemplary embodiment of the present invention the control tree is configured, in addition to pairing the given source subgroup and the given destination subgroup, to assign the given source subgroup and the given destination subgroup to a given instance of data repacking circuitry.


Moreover in accordance with an exemplary embodiment of the present invention the apparatus also includes assigning circuitry other than the control tree, the assigning circuitry being configured to assign the given source subgroup and the given destination subgroup to a given instance of data repacking circuitry.


Further in accordance with an exemplary embodiment of the present invention the control tree includes a reduction tree.





BRIEF DESCRIPTION OF THE DRAWINGS

The present invention will be understood and appreciated more fully from the following detailed description, taken in conjunction with the drawings in which:



FIG. 1A is a simplified pictorial illustration of an exemplary computer system, constructed and operative in accordance with an exemplary embodiment of the present invention;



FIG. 1B is a simplified pictorial illustration of an exemplary data block layout;



FIG. 2 is a simplified pictorial illustration of another exemplary data block layout;



FIG. 3 is a simplified pictorial illustration depicting all-to-all-v initial and final stages;



FIG. 4 is a simplified pictorial illustration depicting direct pairwise exchange;



FIG. 5 is a simplified pictorial illustration depicting an aggregation algorithm;



FIG. 6 is a simplified pictorial illustration depicting initial block distribution for an all-to-all operation, in accordance with an exemplary embodiment of the present invention;



FIG. 7 is a simplified pictorial illustration depicting final block distribution for an all-to-all operation, in accordance with an exemplary embodiment of the present invention;



FIG. 8 is a simplified pictorial illustration depicting all-to-all submatrix distribution, in accordance with another exemplary embodiment of the present invention; and



FIG. 9 is a simplified pictorial illustration depicting transposition of a sub-block, in accordance with exemplary embodiments of the present invention.





DETAILED DESCRIPTION OF AN EMBODIMENT

The all-to-all operation, defined in communication standards such as the Message Passing Interface (MPI) (Forum, 2015), is a collective data operation in which each process sends data to every other process in the collective group, and receives the same amount of data from each process in the group. The data sent to each process is of the same length, a, and is unique, originating from distinct memory locations. In communications standards such as MPI, the concept of operations on processes is decoupled from any particular hardware infrastructure. A collective group, as discussed herein, refers to a group of processes over which a (collective) operation is defined. In the MPI specification a collective group is called a “communicator”, while in OpenSHMEM (see, for example, www.openshmem.org/site/) a collective group is called a “team”.


Reference is now made to FIG. 1A, which is a simplified pictorial illustration of an exemplary computer system, constructed and operative in accordance with an exemplary embodiment of the present invention. The system of FIG. 1A, generally designated 110, comprises a plurality of processes 120, with data (typically data blocks) 130 flowing therebetween. The term “data blocks” (in various grammatical forms) as used herein refers to data the data sent from a member (process, rank, . . . ) i to a member j within a collective group. It is appreciated, as also explained elsewhere herein, For alltoall the size of all blocks is the same (and can be 0), while for alltoallv/w no uniformity is the size of the data blocks is assumed, and some/all of the blocks may be 0.


Exemplary methods of operation of the system of FIG. 1A are described below. In FIG. 1A, by way of non-limiting example, a plurality of CPUs (comprising CPU 1, CPU 2, and CPU N), interconnected in a system-on-chip are shown running the plurality of processes 120. Other system examples, by way of non-limiting example, include: a single CPU; a plurality of systems or servers connected by a network; or any other appropriate system. As described above, the concept of operations on processes, as described herein, is decoupled from any particular hardware infrastructure, although it is appreciated that in any actual implementation some hardware infrastructure (as shown in FIG. 1A or otherwise as described above) would be used.


Reference is now made to FIG. 1B, which is a simplified pictorial illustration of an exemplary data block layout 175 comprising a plurality of data blocks 180, and to FIG. 2, which is a simplified pictorial illustration of another exemplary data block layout 210 comprising a plurality of data blocks 220. FIG. 1B shows the exemplary data block layout 175 before an all-to-all operation is applied, while FIG. 2 shows a corresponding data bock layout 210 after the all-to-all operation is applied. Each data block 180 in FIG. 1B and each data block 220 in FIG. 2 corresponds to a vector of length a.


The algorithms used to implement the all-to-all algorithm tend to fall into two categories—direct exchange and aggregation algorithms.


All-to-all aggregation algorithms are aimed at reducing latency costs, which dominate short data transfers. The all-to-all aggregation algorithms employ data forwarding approaches, to cut down on the number of messages sent, thus reducing latency costs. Such approaches gather/scatter the data from/to multiple sources, producing fewer larger data transfers, but send a given piece of data multiple times. As the number of communication contexts participating in the collective operation becomes too large, aggregation techniques become less efficient than a direct data exchange; this is due to the growing cost of transferring a given piece of data multiple times. The all-to-all algorithms take advantage of the fact that the data length a is a constant of the algorithm, providing sufficient global knowledge to coordinate data exchange through intermediate processes.


The direct exchange algorithms are typically used for all-to-all instances where the length of data being transferred, a, is above a threshold where bandwidth contributions dominate, or when the aggregation techniques aggregate data from too many processes, causing the aggregation techniques to be inefficient.


With growing system sizes, the need to support efficient implementations of small data all-to-all exchanges is increasing, as this is a data exchange pattern used by many High-Performance Computing (HPC) applications. The present invention, in exemplary embodiments thereof, presents a new all-to-all algorithm designed to increase the efficiency of small data exchanges over the full range of communicator sizes. This includes a new aggregation-based algorithm suitable for small data individualized all-to-all data exchange and may be viewed as transposing a distributed matrix. While reference to transposing, in various grammatical forms, are used throughout the present specification and claims, it is appreciated that transposing comprises a way to conceptualize algorithms in accordance with exemplary embodiments of the present invention; for example and without limiting the generality of the foregoing statement, there may be no such conceptualization at the level of (for example) the MPI standard. Such transposing comprises, in exemplary embodiments, changing the position of blocks relative to other blocks, without changing the structure within any block. The algorithms described herein with reference to exemplary embodiments of the present invention benefit from the large amount of concurrency available in the network and are designed to be simple and efficient for implementation by network hardware. Both switching hardware and Host-Channel-Adapter implementations are, in exemplary embodiments, targeted by this new design.


The individualized all-to-all-v/w algorithm is in certain respects similar to the individualized all-to-all data exchange. The individualized all-to-all-w algorithm differs from the all-to-all-v algorithm, in that the data type of each individual transfer may be unique across the function. A change is made to the all-to-all algorithm to support this collective operation. More specifically regarding data type: data being transferred using the MPI standard's interface specified a data type for all data, such as MPI DOUBLE for a double precision word. The alltoallv interface specifies that all data elements are of the same data type. Alltoallw allows a different data type to be specified for each block of data, such as, for example, specifying a data type for data going from process i to process j.


The all-to-all-v/w operation is used for each process to exchange unique data with every other process in the group of processes participating in this collective operation. The size of data exchanged between two given processes may be asymmetric, and each pair may have a different data pattern than other pairs, with large variations in the data sizes being exchanged. A given rank need only have local, API-level information on the data exchanges in which it participates.


The individualized all-to-all-v/w algorithm aimed at the hardware implementation is somewhat similar to the individualized all-to-all algorithm, but requires more meta-data describing the detailed data lengths for implementation. In addition, only messages below a prespecified threshold are handled with this algorithm A direct data exchange is used for the larger messages.


Previously, the algorithms for all-to-all function implementation have fallen into two broad categories:

    • Direct data exchange
    • Aggregation algorithms


The base algorithm definition describes data exchange between all pairs of processes in the collective group, or MPI communicator in the MPI definition. The term “base algorithm” refers to an algorithm definition at the interface level—logically what the function is/does, not how the function result is accomplished. Thus, by way of particular non-limiting example, the base description for alltoallv would be each process sending a block of data to all processes in the group. In certain exemplary embodiments of the present invention, by way of particular non-limiting example, methods are described for carrying out particular functions by aggregating data and by using communication patterns described herein. In general, the algorithm definition conceptually requires O(N2) data exchanges, where N is the group size.


Reference is now made to FIG. 3, which is a simplified pictorial illustration depicting all-to-all-v initial and final stages.



FIG. 3 provides an example of an individualized all-to-all-v, showing initial (reference numeral 310) and final (reference numeral 320) stages. In FIG. 3 notation (i,j) indicates a data segment that started on rank i at position j and should be transferred to rank j at position i. Data sizes of all segments may vary (and even be zero length). Offset of send and receive locations may also vary.


The direct data exchange implementation of the function is the simplest implementation of the all-to-all function. A naïve implementation puts many messages on the network and has the potential to severely degrade network utilization by causing congestion and end-point n→1 contention. (The term “end-point”, as used herein, denotes an entity, such as a process or thread, which contributes data to a collective operation). As a result, algorithms that implement the direct data exchange use a communication pattern, such as pair-wise exchange, as shown in FIG. 4, (Jelena Pjevsivac-Grbovic, 2007), to reduce network load and end-point contention. For large message exchange, which is bandwidth limited, direct data exchange algorithms tend to make good use of network resources. However, when data exchanges are small, latency and message rate costs dominate overall algorithm costs, scale linearly with the N, and do not make good use of system resources. Specifically, FIG. 4 depicts a non-limiting example of direct pair-wise exchange pattern for exchanges involving process 0. The length of each exchange is a, with a bi-directional data exchange.


Aggregation algorithms (Ana Gainaru, 2016) have been used to implement the small data aggregation, with the Bruck (J. Bruck, 1997) algorithm being perhaps the most well-known algorithm in this class. The number of data exchanges in which each process is involved using this approach is O((k−1)*logk(N)), where N is the collective groups size and k is the algorithm radix. FIG. 5 shows the communication pattern for one possible aggregation pattern. Specifically, FIG. 5 depicts a non-limiting example of an aggregation algorithm sending a side data pattern for arbitrary radix k, assuming N is an integer power of the algorithm radix k. N is the size of the collective group. The aggregation algorithms provide better scalability characteristics than the direct exchange. The reduction in the number of messages reduces the latency and message rate costs of the all-to-all operation but increases bandwidth-related costs. If the group does not get too large, the aggregation algorithms outperform direct-exchange algorithms. The message size of each data exchange in the aggregation algorithms scales as O(a*N/k), where a is the all-to-all function message size. As a result, when groups become large, aggregation algorithms are ineffective at reducing the latency of the all-to-all data exchange and will cause the latency to exceed that of the direct data exchange algorithms.


In exemplary embodiments of the present invention, the all-to-all and all-to-all-v/w algorithm is aimed at optimizing the small data exchange by:

    • 1. Defining multiple aggregation points in the network, either switches or Host Channel Adapters (HCAs).
    • 2. Assigning aggregation points for data from sub-blocks of the processes destined to the same or other sub-blocks of the processes to individual aggregators within the network infrastructure. This data may be viewed as a sub-matrix of the distributed matrix. A single aggregator may handle multiple blocks of the submatrix from a single individualized all-to-all or all-to-all-v/w algorithm
    • 3. The sub-blocks may be formed by discontinuous groups of processes, which are in certain exemplary embodiments formed on-the-fly to handle load imbalance in the calling application. In such a case, the matrix sub-blocks may be non-contiguous.
    • 4. The term “aggregator” is used herein to refer to an entity which aggregates a sub-matrix, transposes the same, and then sends results to their final destination. In certain exemplary embodiments of the present invention, the aggregator is a logic block within an HCA. Then the present step 4 may comprise having the aggregator:
      • a. Gather data from all the sources.
      • b. Shuffle the data to prepare so that data destined to a specific process may be sent in as a single message to this destination. The term “shuffle” in the present context refers to re-ordering incoming data from different source processes, such that data destined to a given destination can be conveniently handled. In certain exemplary embodiments of the present invention, data to a single destination may be copied to one contiguous memory block.
      • c. Send the data to the destinations.
    • 5. Data discontinuity and the data source and/or destination is, in certain preferred embodiments, handled at the network edge, so that the aggregators handle only contiguous packed data. That is, data sent from a user or received by a user does not need to be contiguous in the user's virtual memory space; this situation can be conceived like faces of a cube, in which 2 of the 6 faces will not be in contiguous memory addresses. Hardware sends streams of contiguous data. Handling the non-contiguous→contiguous “packing” is done at the first step (either by using the CPU to pack the data into a contiguous buffer, or by using HCA gather capabilities). Similarly, unpacking non-contiguous data into user buffers can be done either by the HCA delivering the data to a contiguous destination buffer, and then using the CPU to unpack, or by using the HCA scatter capabilities. Thus, algorithmic data manipulation in the intermediate steps may treat contiguous, packed data.


The present invention, in exemplary embodiments thereof, may be viewed as using aggregation points within the network to collect data from a non-contiguous portion of a distributed matrix, transpose the data, and send the data to their destinations.


In exemplary embodiments, the invention may be summarized as follows:

    • 1. Data layout is viewed as a distributed matrix, with each process holding a block of data destined to each other process. For the all-to-all algorithm, the data block size is the same for all source data blocks; while for all-to-all-v/w, the data block sizes may be of different lengths, including length zero. In notation used herein, the horizontal index indicates the data source and the vertical index its destination.
    • 2. The collective operation performs a transpose of the data blocks.
    • 3. To transpose the distributed matrix, the matrix is subdivided into rectangular submatrices, of dimension dh×dv, where dh is the size in the horizontal dimension and dv is the size in the vertical dimension. Subblocks need not be logically contiguous. The submatrices may be predefined, or may be determined at run-time based on some criteria, such as, by way of non-limiting example, an order of entry into the all-to-all operation.
    • 4. Provide a data repacking unit, which accepts data from a specified set of sources, the data being destined to a specified set of destinations, repacks the data by destination, and sends the data to the specified destinations. In exemplary embodiments, the data repacking unit has subunits for each operation described. In certain exemplary embodiments of the present invention, an aggregator, as described herein, would comprise or make use of a data repacking unit.
    • 5. The transposition of a submatrix is assigned to a given data repacking unit, with each unit being assigned multiple submatrices to transpose. In certain exemplary embodiments of the present invention, the assignment may be carried out by the control tree mentioned below in point 7; alternatively another component (such as, by way of non-limiting example, a software component) may be provided to carry out the assignment.
    • 6. The data repacking unit may be implemented as appropriate within the system. For example, it may be implemented in a switch ASIC, Host-Channel-Adapter (HCA) unit, CPU or other appropriate hardware, and may be implemented in hardware, firmware, software, or in any appropriate combination thereof.
    • 7. A reduction tree is used as a control tree to control the collective operation, in the following manner:
      • 7.1. Each process in the group registers itself with the control tree, by passing up an arrival notification to the control tree.
      • 7.2. Once all members of a subgroup arrive, the subgroup is marked as ready for operation (ready for send/receive).
      • 7.3. As source and destination group of a given submatrix are ready, the relevant data repacking unit schedules the data movement.
      • 7.4. Data is transferred from the source processes to the data repacking unit. This unit repacks the data and sends it to the appropriate destinations.
      • 7.5. Each source process is notified of completion, as is each destination process. In certain exemplary embodiments of the present invention, this is accomplished by the aggregator notifying the source and destination blocks of completion; by way of particular non-limiting example, this may be accomplished using the control tree.
      • 7.6. The operation completes locally at each process, once all expected data has been received, and transferring all source data is complete.


        In exemplary embodiments, a more detailed explanation is as follows:


In all-to-all and all-to-all-v/w algorithms, each process has a unique block of data destined for each other process in the group. The primary way all-to-all differs from all-to-all-v is in the data layout pattern. All-to-all data blocks are all of the same size, whereas the all-to-all-v/w algorithms support data blocks of differing sizes, and the data blocks need not be ordered in a monotonically increasing order within the user buffer.


The layout of blocks of data for the all-to-all algorithm may be viewed as a distributed matrix, with the all-to-all algorithm transposing this block distribution. It is important to note that, in exemplary embodiments of the present invention, the data within each block is not rearranged in the transposition, just the order of the data blocks themselves.



FIG. 6 shows an exemplary all-to-all data source data block layout for a group of size six, showing an exemplary initial distribution for an all-to-all operation. Each column represents that data block each process has for all the other processes. Each block is labeled with a two-index label, with the first index indicating the process from which the data originates with the second index being the rank (the term “rank”, being used in accordance with the MPI standard, in which each member of the communicator (the group of processes that defines the collective) is given a rank, or an ID) of that block's destination process.


After the all-to-all operation is applied to the data in the example of FIG. 6, with the data blocks transposed, the data-block layout displayed in FIG. 7 results.


With the all-to-all-v/w algorithms a similar data transposition is performed. Such transform differs as follows:

    • 1. The data size may differ between blocks, and may even be of length zero.
    • 2. The blocks of data both at the source and destination buffers are not necessarily arranged in an increasing order by destination (source buffer) or source (result buffer). The actual block ordering is specified as part of the all-to-all-v/w operations.


      Therefore, similar communication patterns may be used to implement all-to-all and all-to-all-v/w.


The actual matrix transform is performed over sub-blocks of data. The term “the “actual matrix transform” is used herein because the blocks of data transfer defined by the operation can be viewed as a matrix transform, when each element in the matrix is a block of data. The columns of the matrix are the blocks of data owned by each process. Each process has a block of data associated with every process in the group, so the matrix can be viewed as a square matrix. For alltoall, the size of all the blocks is identical, for alltoall-v and alltoall-w, block sizes may be different. From a block-like view of the data layout (not the actual size of each block) alltoall-v and alltoall-w still are square.


For the purpose of the transform, horizontal submatrix dimension, dh, and vertical submatrix dimension, dv, are defined. The sub-block dimensions need not be an integer divisor of the full matrix dimension, and dh and dv need not be equal. Incomplete sub-blocks are permitted; that is, for a given group size, there are subgroups for which the ratio of the groups size to the sub-block size is not an integer. This situation gives “leftover” blocks at the edges. By way of particular non-limiting example, such “leftover” blocks would be present in a matrix of size 11, with sub-blocks of size 3. Finally, the vertical and horizontal ranges of values in the full matrix need not be contiguous, e.g., when mapped onto the full matrix, such a submatrix may be distributed into several different contiguous blocks of data over the matrix.


As an example, if we take dh=hv=2, and we use processes group {1,2}, {0,3} and {4,5} to sub-block the matrix, FIG. 8 uses coding [a] through [i] to show how the full matrix, may, in a non-limiting example, be subdivided into 2×2 sub-blocks. Note that there are three distributed sub-blocks in the example: 1) data blocks (0,0)(0,3)(3,0)(3,3), shown as [a]; 2) data blocks (0,1)(0,2)(3,1)(3,2), shown as [c]; and 3) (1,0)(2,0)(1,3)(2,3), shown as [b].


The full end-to-end all-to-all is orchestrated, in exemplary embodiments of the present invention, using a reduction tree. As processes make a call to the collective operation, the reduction tree is used by each process to register with the collective operation. When all members of a sub-group have registered with the operation, the sub-group is marked as active. When both source and destination subgroup are active, that subgroup may be transposed.


In certain exemplary embodiments of the present invention, the collective operation is executed in the following manner:

    • 1. Each process in the group registers itself with the control tree, by passing up an arrival notification to the controller.
    • 2. Once all members of a subgroup arrive, this subgroup is marked as ready for operation.
    • 3. As source and destination groups are ready, these are paired and assigned to a data repacking unit.
    • 4. Data is transferred from the source processes to the data repacking unit. This unit repacks the data and sends it to the appropriate destinations.
    • 5. Each source process is notified of completion, as it each destination process.
    • 6. The operation completes locally at each process, once all expected data has been received, and transferring all source data is complete.



FIG. 9 shows how one of the data-repacking units 910 in the system is used, in a non-limiting exemplary embodiment, to transpose the submatrix defined by the horizontal subgroup {0,3} and vertical subgroup {1,2}. Processes 0 and 3 each sends its portion of the submatrix to the data-repacking unit, which rearranges the data, sending to processes 1 and 2. In the specific non-limiting example shown in FIG. 9, process 0 has the data elements (0,1) and (0,2), process 3 has the data elements (3,1) and (3,2). This data is sent to the controller which sends (0,1) and (3,1) to process 1 and (0,2) and (3,2) to process 2. Final data-placement in the result buffer is handled by the end-point. In general, in exemplary embodiments the repacking unit 910 treats all data processed thereby as a contiguous “blob” of data—the repacking unit 910 does not recognize any structure in the data. The final data distribution at the end-points within each block may be contiguous, in which case the repacking unit and the destination process will have the same view of the data. However, the final data layout at the destination process may be non-contiguous, in which case it is the end-point that distributes the data appropriately at the destination. It is appreciated that the end-point or any other appropriate system component may distribute the data appropriately.


REFERENCES



  • Ana Gainaru, R. L. Graham, Artem Polyakov, Gilad Shainer (2016). Using InfiniBand Hardware Gather-Scatter Capabilities to Optimize MPI All-to-All (Vol. Proceedings of the 23rd European MPI Users' Group Meeting). Edinburgh, United Kingdom: ACM.

  • MPI Forum, (2015). Message Passing Interface. Knoxville: University of Tennessee.

  • J. Bruck, Ching-Tien Ho, Shlomo Kipnis, Derrick Weathersby (1997). Efficient algorithms for all-to-all communications in multi port message passing systems. In IEEE Transactions on Parallel and Distributed Systems, pages 298-309.

  • Jelena Pjevsivac-Grbovic, Thara Angskun, Geroge Bosilca, Graham Fagg, Edgar Gabriel, Jack Dongarra, (2007). Performance analysis of MPI collective operations. Cluster Computing.



It is appreciated that software components of the present invention may, if desired, be implemented in ROM (read only memory) form. The software components may, generally, be implemented in hardware, if desired, using conventional techniques. It is further appreciated that the software components may be instantiated, for example: as a computer program product or on a tangible medium. In some cases, it may be possible to instantiate the software components as a signal interpretable by an appropriate computer, although such an instantiation may be excluded in certain embodiments of the present invention.


It is appreciated that various features of the invention which are, for clarity, described in the contexts of separate embodiments may also be provided in combination in a single embodiment. Conversely, various features of the invention which are, for brevity, described in the context of a single embodiment may also be provided separately or in any suitable subcombination.


It will be appreciated by persons skilled in the art that the present invention is not limited by what has been particularly shown and described hereinabove. Rather the scope of the invention is defined by the appended claims and equivalents thereof:

Claims
  • 1. A method comprising: providing a plurality of processes interconnected by a network, each of the plurality of processes being configured to hold a block of data destined for others of the plurality of processes;receiving from one or more of the processes a set of data for all-to-all data exchange, the set of data being configured as a plurality of blocks of data in a matrix as matrix data, the matrix being distributed among the plurality of processes;transposing the matrix data by changing the position of selected blocks of data of the plurality of blocks of data relative to the other blocks of data of the plurality of the blocks of data, without changing the structure of each of the blocks of data;sending the transposed matrix data over the network; andreceiving and repacking the transposed matrix data from the network, and conveying the repacked matrix data to destination processes.
  • 2. The method according to claim 1, and also comprising providing a control tree configured to control the plurality of processes and repacking the transposed matrix data.
  • 3. The method according to claim 2, and wherein the control tree is further configured to: receive registration messages from each of the plurality of processes;mark a given subgroup of the plurality of processes as ready for operation when registration messages have been received from all members of said given subgroup;when a given subgroup which is a source subgroup and a corresponding subgroup which is a destination subgroup are ready for operation, pair the given source subgroup and the given destination subgroup; andnotify each said source subgroup and each said destination subgroup when operations relating to each said source subgroup and each said destination subgroup have completed.
  • 4. The method according to claim 3, and wherein the control tree is configured, in addition to pairing the given source subgroup and the given destination subgroup, to assign the given source subgroup and the given destination subgroup to an instance of data repacking circuitry.
  • 5. The method according to claim 2 and wherein the control tree comprises a reduction tree.
  • 6. The method according to claim 2, and also comprising providing assigning circuitry other than the control tree, the assigning circuitry being configured to assign a given source subgroup and a given destination subgroup to an instance of data repacking circuitry.
  • 7. A computer software product for use in conjunction with a plurality of processes interconnected by a network, each of the plurality of processes being configured to hold a block of data destined for others of the plurality of processes, the product comprising a non-transitory computer-readable medium in which program instructions are stored, which instructions, when read by one or more processors, cause the one or more processors: to receive from one or more of the processes a set of data for all-to-all data exchange, the set of data being configured as a plurality of blocks of data in a matrix as matrix data, the matrix being distributed among the plurality of processes;to transpose the matrix data by changing the position of selected blocks of data of the plurality of blocks of data relative to the other blocks of data of the plurality of the blocks of data, without changing the structure of each of the blocks of data;to send the transposed matrix data over the network; andto receive and repack the transposed matrix data from the network, and to convey the repacked matrix data to destination processes.
  • 8. The product according to claim 7, wherein the instructions cause the one or more processors to provide a control tree configured to control the plurality of processes and repacking the transposed matrix data.
  • 9. The product according to claim 8, and wherein the control tree is further configured to: receive registration messages from each of the plurality of processes;mark a given subgroup of the plurality of processes as ready for operation when registration messages have been received from all members of said given subgroup;when a given subgroup which is a source subgroup and a corresponding subgroup which is a destination subgroup are ready for operation, pair the given source subgroup and the given destination subgroup; andnotify each said source subgroup and each said destination subgroup when operations relating to each said source subgroup and each said destination subgroup have completed.
  • 10. The product according to claim 9, and wherein the control tree is configured, in addition to pairing the given source subgroup and the given destination subgroup, to assign the given source subgroup and the given destination subgroup to an instance of data repacking circuitry.
  • 11. The product according to claim 8, and wherein the control tree comprises a reduction tree.
  • 12. The product according to claim 8, wherein the instructions cause the one or more processes to assign a given source subgroup and a given destination subgroup to an instance of data repacking circuitry.
CROSS-REFERENCE TO RELATED APPLICATIONS

The present application is a continuation of U.S. patent application Ser. No. 17/495,824, filed Oct. 7, 2021, which is a continuation of U.S. patent application Ser. No. 16/789,458, filed Feb. 13, 2020 (now U.S. Pat. No. 11,196,586), which claims the benefit of U.S. Provisional Patent Application 62/809,786, filed Feb. 25, 2019.

US Referenced Citations (299)
Number Name Date Kind
4933969 Marshall et al. Jun 1990 A
5068877 Near et al. Nov 1991 A
5325500 Bell et al. Jun 1994 A
5353412 Douglas et al. Oct 1994 A
5404565 Gould et al. Apr 1995 A
5408469 Opher et al. Apr 1995 A
5606703 Brady et al. Feb 1997 A
5944779 Blum Aug 1999 A
6041049 Brady Mar 2000 A
6115394 Balachandran et al. Sep 2000 A
6212197 Christensen et al. Apr 2001 B1
6370502 Wu et al. Apr 2002 B1
6438137 Turner et al. Aug 2002 B1
6483804 Muller et al. Nov 2002 B1
6507562 Kadansky et al. Jan 2003 B1
6728862 Wilson Apr 2004 B1
6816492 Turner et al. Nov 2004 B1
6857004 Howard et al. Feb 2005 B1
6937576 Di Benedetto et al. Aug 2005 B1
7102998 Golestani Sep 2006 B1
7124180 Ranous Oct 2006 B1
7164422 Wholey, III et al. Jan 2007 B1
7171484 Krause et al. Jan 2007 B1
7224669 Kagan et al. May 2007 B2
7245627 Goldenberg et al. Jul 2007 B2
7313582 Bhanot et al. Dec 2007 B2
7327693 Rivers et al. Feb 2008 B1
7336646 Muller Feb 2008 B2
7346698 Hannaway Mar 2008 B2
7555549 Campbell et al. Jun 2009 B1
7613774 Caronni et al. Nov 2009 B1
7636424 Halikhedkar et al. Dec 2009 B1
7636699 Stanfill Dec 2009 B2
7676597 Kagan et al. Mar 2010 B2
7738443 Kumar Jun 2010 B2
7760743 Shokri et al. Jul 2010 B2
8213315 Crupnicoff et al. Jul 2012 B2
8255475 Kagan et al. Aug 2012 B2
8370675 Kagan Feb 2013 B2
8380880 Gulley et al. Feb 2013 B2
8510366 Anderson et al. Aug 2013 B1
8645663 Kagan et al. Feb 2014 B2
8738891 Karandikar et al. May 2014 B1
8761189 Shachar et al. Jun 2014 B2
8768898 Trimmer Jul 2014 B1
8775698 Archer et al. Jul 2014 B2
8811417 Bloch et al. Aug 2014 B2
9110860 Shahar Aug 2015 B2
9189447 Faraj Nov 2015 B2
9294551 Froese et al. Mar 2016 B1
9344490 Bloch et al. May 2016 B2
9397960 Arad et al. Jul 2016 B2
9456060 Pope et al. Sep 2016 B2
9563426 Bent et al. Feb 2017 B1
9626329 Howard Apr 2017 B2
9756154 Jiang Sep 2017 B1
10015106 Florissi et al. Jul 2018 B1
10027601 Narkis et al. Jul 2018 B2
10158702 Bloch et al. Dec 2018 B2
10187400 Castro et al. Jan 2019 B1
10284383 Bloch et al. May 2019 B2
10296351 Kohn et al. May 2019 B1
10305980 Gonzalez et al. May 2019 B1
10318306 Kohn et al. Jun 2019 B1
10320508 Shimizu et al. Jun 2019 B2
10425350 Florissi Sep 2019 B1
10515045 Mattina Dec 2019 B1
10521283 Shuler et al. Dec 2019 B2
10528518 Graham et al. Jan 2020 B2
10541938 Timmerman et al. Jan 2020 B1
10547553 Shattah et al. Jan 2020 B2
10621489 Appuswamy et al. Apr 2020 B2
10727966 Izenberg et al. Jul 2020 B1
11088971 Brody et al. Aug 2021 B2
11336383 Mula et al. May 2022 B2
11388263 Levi et al. Jul 2022 B2
20020010844 Noel et al. Jan 2002 A1
20020035625 Tanaka Mar 2002 A1
20020150094 Cheng et al. Oct 2002 A1
20020150106 Kagan et al. Oct 2002 A1
20020152315 Kagan et al. Oct 2002 A1
20020152327 Kagan et al. Oct 2002 A1
20020152328 Kagan et al. Oct 2002 A1
20020165897 Kagan et al. Nov 2002 A1
20030002483 Zwack Jan 2003 A1
20030018828 Craddock et al. Jan 2003 A1
20030061417 Craddock et al. Mar 2003 A1
20030065856 Kagan et al. Apr 2003 A1
20030120835 Kale et al. Jun 2003 A1
20040030745 Boucher et al. Feb 2004 A1
20040062258 Grow et al. Apr 2004 A1
20040078493 Blumrich et al. Apr 2004 A1
20040120331 Rhine et al. Jun 2004 A1
20040123071 Stefan et al. Jun 2004 A1
20040174820 Ricciulli Sep 2004 A1
20040252685 Kagan et al. Dec 2004 A1
20040260683 Chan et al. Dec 2004 A1
20050097300 Gildea et al. May 2005 A1
20050122329 Janus Jun 2005 A1
20050129039 Biran et al. Jun 2005 A1
20050131865 Jones et al. Jun 2005 A1
20050223118 Tucker et al. Oct 2005 A1
20050281287 Ninomi et al. Dec 2005 A1
20060095610 Arndt et al. May 2006 A1
20060282838 Gupta et al. Dec 2006 A1
20070127396 Jain et al. Jun 2007 A1
20070127525 Sarangam et al. Jun 2007 A1
20070162236 Lamblin et al. Jul 2007 A1
20080040792 Larson et al. Feb 2008 A1
20080104218 Liang et al. May 2008 A1
20080126564 Wilkinson May 2008 A1
20080168471 Benner et al. Jul 2008 A1
20080181260 Vonog et al. Jul 2008 A1
20080192750 Ko et al. Aug 2008 A1
20080219159 Chateau et al. Sep 2008 A1
20080244220 Lin et al. Oct 2008 A1
20080263329 Archer et al. Oct 2008 A1
20080288949 Bohra et al. Nov 2008 A1
20080298380 Rittmeyer et al. Dec 2008 A1
20080307082 Cai et al. Dec 2008 A1
20090037377 Archer et al. Feb 2009 A1
20090063816 Arimilli et al. Mar 2009 A1
20090063817 Arimilli et al. Mar 2009 A1
20090063891 Arimilli et al. Mar 2009 A1
20090182814 Tapolcai et al. Jul 2009 A1
20090240838 Berg et al. Sep 2009 A1
20090247241 Gollnick et al. Oct 2009 A1
20090292905 Faraj Nov 2009 A1
20090296699 Hefty Dec 2009 A1
20090327444 Archer et al. Dec 2009 A1
20100017420 Archer Jan 2010 A1
20100049836 Kramer Feb 2010 A1
20100074098 Zeng et al. Mar 2010 A1
20100095086 Eichenberger et al. Apr 2010 A1
20100185719 Howard Jul 2010 A1
20100241828 Yu et al. Sep 2010 A1
20100274876 Kagan et al. Oct 2010 A1
20100329275 Johnsen et al. Dec 2010 A1
20110060891 Jia Mar 2011 A1
20110066649 Berlyant et al. Mar 2011 A1
20110093258 Xu et al. Apr 2011 A1
20110119673 Bloch et al. May 2011 A1
20110173413 Chen et al. Jul 2011 A1
20110219208 Asaad Sep 2011 A1
20110238956 Arimilli et al. Sep 2011 A1
20110258245 Blocksome et al. Oct 2011 A1
20110276789 Chambers et al. Nov 2011 A1
20120063436 Thubert et al. Mar 2012 A1
20120117331 Krause et al. May 2012 A1
20120131309 Johnson May 2012 A1
20120254110 Takemoto Oct 2012 A1
20130117548 Grover et al. May 2013 A1
20130159410 Lee et al. Jun 2013 A1
20130159568 Shahar et al. Jun 2013 A1
20130215904 Zhou et al. Aug 2013 A1
20130250756 Johri et al. Sep 2013 A1
20130312011 Kumar et al. Nov 2013 A1
20130318525 Palanisamy et al. Nov 2013 A1
20130336292 Kore et al. Dec 2013 A1
20140019574 Cardona et al. Jan 2014 A1
20140033217 Vajda et al. Jan 2014 A1
20140040542 Kim et al. Feb 2014 A1
20140047341 Breternitz et al. Feb 2014 A1
20140095779 Forsyth Apr 2014 A1
20140122831 Uliel et al. May 2014 A1
20140136811 Fleischer et al. May 2014 A1
20140189308 Hughes et al. Jul 2014 A1
20140211804 Makikeni et al. Jul 2014 A1
20140258438 Ayoub Sep 2014 A1
20140280420 Khan Sep 2014 A1
20140281370 Khan Sep 2014 A1
20140362692 Wu et al. Dec 2014 A1
20140365548 Mortensen Dec 2014 A1
20140379714 Hankins Dec 2014 A1
20150046741 Yen et al. Feb 2015 A1
20150055508 Ashida et al. Feb 2015 A1
20150074373 Sperber et al. Mar 2015 A1
20150106578 Warfield et al. Apr 2015 A1
20150143076 Khan May 2015 A1
20150143077 Khan May 2015 A1
20150143078 Khan et al. May 2015 A1
20150143079 Khan May 2015 A1
20150143085 Khan May 2015 A1
20150143086 Khan May 2015 A1
20150154058 Miwa et al. Jun 2015 A1
20150178211 Hiramoto et al. Jun 2015 A1
20150180785 Annamraju Jun 2015 A1
20150188987 Reed et al. Jul 2015 A1
20150193271 Archer Jul 2015 A1
20150212972 Boettcher et al. Jul 2015 A1
20150261720 Kagan et al. Sep 2015 A1
20150269116 Raikin et al. Sep 2015 A1
20150278347 Meyer et al. Oct 2015 A1
20150318015 Bose et al. Nov 2015 A1
20150347012 Dewitt et al. Dec 2015 A1
20150365494 Cardona et al. Dec 2015 A1
20150379022 Puig et al. Dec 2015 A1
20160055225 Xu et al. Feb 2016 A1
20160092362 Barron et al. Mar 2016 A1
20160105494 Reed et al. Apr 2016 A1
20160112531 Milton et al. Apr 2016 A1
20160117277 Raindel et al. Apr 2016 A1
20160119244 Wang et al. Apr 2016 A1
20160179537 Kunzman et al. Jun 2016 A1
20160219009 French Jul 2016 A1
20160246646 Craciunas et al. Aug 2016 A1
20160248656 Anand et al. Aug 2016 A1
20160283422 Crupnicoff et al. Sep 2016 A1
20160294793 Larson et al. Oct 2016 A1
20160299872 Vaidyanathan et al. Oct 2016 A1
20160342568 Burchard et al. Nov 2016 A1
20160352598 Reinhardt et al. Dec 2016 A1
20160364350 Sanghi et al. Dec 2016 A1
20170063613 Bloch et al. Mar 2017 A1
20170093715 McGhee et al. Mar 2017 A1
20170116154 Palmer et al. Apr 2017 A1
20170187496 Shalev et al. Jun 2017 A1
20170187589 Pope et al. Jun 2017 A1
20170187629 Shalev et al. Jun 2017 A1
20170187846 Shalev et al. Jun 2017 A1
20170192782 Valentine et al. Jul 2017 A1
20170199844 Burchard et al. Jul 2017 A1
20170262517 Horowitz et al. Sep 2017 A1
20170308329 A et al. Oct 2017 A1
20170331926 Raveh et al. Nov 2017 A1
20170344589 Kafai et al. Nov 2017 A1
20180004530 Vorbach Jan 2018 A1
20180046901 Xie et al. Feb 2018 A1
20180047099 Bonig et al. Feb 2018 A1
20180089278 Bhattacharjee et al. Mar 2018 A1
20180091442 Chen et al. Mar 2018 A1
20180097721 Matsui et al. Apr 2018 A1
20180115529 Munger et al. Apr 2018 A1
20180173673 Daglis et al. Jun 2018 A1
20180262551 Demeyer Sep 2018 A1
20180278549 Mula et al. Sep 2018 A1
20180285151 Wang et al. Oct 2018 A1
20180285316 Thorson et al. Oct 2018 A1
20180287725 Rabinovich et al. Oct 2018 A1
20180287928 Levi et al. Oct 2018 A1
20180302324 Kasuya Oct 2018 A1
20180321912 Li et al. Nov 2018 A1
20180321938 Boswell et al. Nov 2018 A1
20180349212 Liu Dec 2018 A1
20180367465 Levi Dec 2018 A1
20180375781 Chen et al. Dec 2018 A1
20190018805 Benisty Jan 2019 A1
20190026250 Das Sarma et al. Jan 2019 A1
20190044827 Ganapathi et al. Feb 2019 A1
20190044875 Murty et al. Feb 2019 A1
20190044889 Serres et al. Feb 2019 A1
20190056972 Zhou et al. Feb 2019 A1
20190065208 Liu et al. Feb 2019 A1
20190068501 Schneder et al. Feb 2019 A1
20190102090 Guim et al. Apr 2019 A1
20190102179 Fleming et al. Apr 2019 A1
20190102338 Tang et al. Apr 2019 A1
20190102640 Balasubramanian Apr 2019 A1
20190114533 Ng et al. Apr 2019 A1
20190121388 Knowles Apr 2019 A1
20190124524 Gormley Apr 2019 A1
20190138638 Pal et al. May 2019 A1
20190141133 Rajan et al. May 2019 A1
20190147092 Pal et al. May 2019 A1
20190149486 Bohrer et al. May 2019 A1
20190149488 Bansal et al. May 2019 A1
20190171612 Shahar et al. Jun 2019 A1
20190187774 Yi et al. Jun 2019 A1
20190235866 Das Sarma et al. Aug 2019 A1
20190278737 Kozomora et al. Sep 2019 A1
20190303168 Fleming, Jr. et al. Oct 2019 A1
20190303263 Fleming, Jr. et al. Oct 2019 A1
20190319730 Webb et al. Oct 2019 A1
20190324431 Cella et al. Oct 2019 A1
20190339688 Cella et al. Nov 2019 A1
20190347099 Eapen et al. Nov 2019 A1
20190369994 Parandeh Afshar et al. Dec 2019 A1
20190377580 Vorbach Dec 2019 A1
20190379714 Levi et al. Dec 2019 A1
20200005859 Chen et al. Jan 2020 A1
20200034145 Bainville et al. Jan 2020 A1
20200057748 Danilak Feb 2020 A1
20200103894 Cella et al. Apr 2020 A1
20200106828 Elias et al. Apr 2020 A1
20200137013 Jin Apr 2020 A1
20200202246 Lin et al. Jun 2020 A1
20200265043 Graham et al. Aug 2020 A1
20200274733 Graham et al. Aug 2020 A1
20210203621 Ylisirnio et al. Jul 2021 A1
20210218808 Graham et al. Jul 2021 A1
20210234753 Ben-Moshe et al. Jul 2021 A1
20210243140 Levi et al. Aug 2021 A1
20210297151 Levi et al. Sep 2021 A1
20220006606 Levi et al. Jan 2022 A1
20220029854 Graham et al. Jan 2022 A1
20220078043 Marcovitch et al. Mar 2022 A1
20220188147 Nudelman et al. Jun 2022 A1
20220201103 Keppel et al. Jun 2022 A1
20230089099 Nudelman et al. Mar 2023 A1
Foreign Referenced Citations (6)
Number Date Country
2012216611 Mar 2013 AU
103095607 May 2013 CN
109617640 Apr 2019 CN
03044677 May 2003 WO
2016150833 Sep 2016 WO
2016167915 Oct 2016 WO
Non-Patent Literature Citations (65)
Entry
Mellanox Technologies, “InfiniScale IV: 36-port 40GB/s Infiniband Switch Device”, pp. 1-2, year 2009.
Mellanox Technologies Inc., “Scaling 10Gb/s Clustering at Wire-Speed”, pp. 1-8, year 2006.
IEEE 802.1D Standard “IEEE Standard for Local and Metropolitan Area Networks—Media Access Control (MAC) Bridges”, IEEE Computer Society, pp. 1-281, Jun. 9, 2004.
IEEE 802.1AX Standard “IEEE Standard for Local and Metropolitan Area Networks—Link Aggregation”, IEEE Computer Society, pp. 1-163, Nov. 3, 2008.
Turner et al., “Multirate Clos Networks”, IEEE Communications Magazine, pp. 1-11, Oct. 2003.
Thayer School of Engineering, “An Slightly Edited Local Copy of Elements of Lectures 4 and 5”, Dartmouth College, pp. 1-5, Jan. 15, 1998 http://people.seas.harvard.edu/˜jones/cscie129/nu_lectures/lecture11/switching/clos_network/clos_network.html.
“MPI: A Message-Passing Interface Standard,” Message Passing Interface Forum, version 3.1, pp. 1-868, Jun. 4, 2015.
Coti et al., “MPI Applications on Grids: a Topology Aware Approach,” Proceedings of the 15th International European Conference on Parallel and Distributed Computing (EuroPar'09), pp. 1-12, Aug. 2009.
Petrini et al., “The Quadrics Network (QsNet): High-Performance Clustering Technology,” Proceedings of the 9th IEEE Symposium on Hot Interconnects (Hotl'01), pp. 1-6, Aug. 2001.
Sancho et al., “Efficient Offloading of Collective Communications in Large-Scale Systems,” Proceedings of the 2007 IEEE International Conference on Cluster Computing, pp. 1-10, Sep. 17-20, 2007.
Priest et al., “You've Got Mail (YGM): Building Missing Asynchronous Communication Primitives”, IEEE International Parallel and Distributed Processing Symposium Workshops, pp. 221-230, year 2019.
InfiniBand Architecture Specification, vol. 1, Release 1.2.1, pp. 1-1727, Nov. 2007.
Deming, “Infiniband Architectural Overview”, Storage Developer Conference, pp. 1-70, year 2013.
Fugger et al., “Reconciling fault-tolerant distributed computing and systems-on-chip”, Distributed Computing, vol. 24, Issue 6, pp. 323-355, Jan. 2012.
Wikipedia, “System on a chip”, pp. 1-4, Jul. 6, 2018.
Villavieja et al., “On-chip Distributed Shared Memory”, Computer Architecture Department, pp. 1-10, Feb. 3, 2011.
Wikipedia, “Nagle's algorithm”, pp. 1-4, Dec. 12, 2019.
Bruck et al., “Efficient Algorithms for All-to-All Communications in Multiport Message-Passing Systems”, IEEE Transactions on Parallel and Distributed Systems, vol. 8, No. 11, pp. 1143-1156, Nov. 1997.
Gainaru et al., “Using InfiniBand Hardware Gather-Scatter Capabilities to Optimize MPI All-to-All”, EuroMPI '16, Edinburgh, United Kingdom, pp. 1-13, year 2016.
Pjesivac-Grbovic et al., “Performance analysis of MPI collective operations”, Cluster Computing, pp. 1-25, year 2007.
Bruck et al., “Efficient Algorithms for All-to-All Communications in Multiport Message-Passing Systems”, Proceedings of the sixth annual ACM symposium on Parallel algorithms and architectures, pp. 298-309, Aug. 1, 1994.
Chiang et al., “Toward supporting data parallel programming on clusters of symmetric multiprocessors”, Proceedings International Conference on Parallel and Distributed Systems, pp. 607-614, Dec. 14, 1998.
Danalis et al., “PTG: an abstraction for unhindered parallelism”, 2014 Fourth International Workshop on Domain-Specific Languages and High-Level Frameworks for High Performance Computing, pp. 1-10, Nov. 17, 2014.
Cosnard et al., “Symbolic Scheduling of Parameterized Task Graphs on Parallel Machines,” Combinatorial Optimization book series (COOP, vol. 7), pp. 217-243, year 2000.
Jeannot et al., “Automatic Multithreaded Parallel Program Generation for Message Passing Multiprocessors using paramerized Task Graphs”, World Scientific, pp. 1-8, Jul. 23, 2001.
Stone, “An Efficient Parallel Algorithm for the Solution of a Tridiagonal Linear System of Equations,” Journal of the Association for Computing Machinery, vol. 10, No. 1, pp. 27-38, Jan. 1973.
Kogge et al., “A Parallel Algorithm for the Efficient Solution of a General Class of Recurrence Equations,” IEEE Transactions on Computers, vol. C-22, No. 8, pp. 786-793, Aug. 1973.
Hoefler et al., “Message Progression in Parallel Computing—To Thread or not to Thread?”, 2008 IEEE International Conference on Cluster Computing, pp. 1-10, Tsukuba, Japan, Sep. 29-Oct. 1, 2008.
Wikipedia, “Loop unrolling,” pp. 1-9, last edited Sep. 9, 2020 downloaded from https://en.wikipedia.org/wiki/Loop_unrolling.
Chapman et al., “Introducing OpenSHMEM: SHMEM for the PGAS Community,” Proceedings of the Forth Conferene on Partitioned Global Address Space Programming Model, pp. 1-4, Oct. 2010.
Yang et al., “SwitchAgg: A Further Step Toward In-Network Computing,” 2019 IEEE International Conference on Parallel & Distributed Processing with Applications, Big Data & Cloud Computing, Sustainable Computing & Communications, Social Computing & Networking, pp. 36-45, Dec. 2019.
Pacheco, “A User's Guide to MPI,” Department of Mathematics, University of San Francisco, CA, USA, pp. 1-51, Mar. 30, 1998.
Wikipedia, “Message Passing Interface,” pp. 1-16, last edited Nov. 7, 2021, as downloaded from https://en.wikipedia.org/wiki/Message_Passing_Interface.
“Message Passing Interface (MPI): History and Evolution,” Virtual Workshop, Cornell University Center for Advanced Computing, NY, USA, pp. 1-2, year 2021, as downloaded from https://cvw.cac.cornell.edu/mpi/history.
Xu et al., “SLOAVx: Scalable LOgarithmic AlltoallV Algorithm for Hierarchical Multicore Systems”, 13th IEEE/ACM International Symposium on Cluster, Cloud, and Grid Computing, pp. 369-376, year 2013.
Nvidia Corporation, “Nvidia Scalable Hierarchical Aggregation and Reduction Protocol (SHARP),” Rev. 3.0.0, pp. 1-3, year 2023.
Graham, U.S. Appl. No. 18/074,563, filed Dec. 5, 2022.
Graham, U.S. Appl. No. 18/105,846, filed Feb. 5, 2023.
Graham, U.S. Appl. No. 63/356,923, filed Jun. 29, 2022.
Oltchik et al, U.S. Appl. No. 18/451,134, filed Aug. 17, 2023.
CN Application # 202110742521.4 Office Action dated Jan. 30, 2024.
EP Patent Application 20156490.3 Office Action dated Feb. 27, 2024.
IEEE Standard 1588-2008, “IEEE Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems”, pp. 1-289, year 2008.
Weibel et al., “Implementation and Performance of Time Stamping Techniques”, 2004 Conference on IEEE 1588, pp. 1-29, Sep. 28, 2004.
InfiniBandTM Architecture Specification vol. 1, Release 1.2.1,pp. 1-1727, Nov. 2007.
Lu et al., “A Fast CRC Update Implementation”, Computer Engineering Laboratory, Electrical Engineering Department, pp. 113-120, Oct. 8, 2003.
Mellette et al., “Toward Optical Switching in the Data Center”, IEEE 19th International Conference on High Performance Switching and Routing (HPSR), pp. 1-6, Bucharest, Romania, Jun. 18-20, 2018.
Bakopoulos et al., “NEPHELE: an end-to-end scalable and dynamically reconfigurable optical architecture for application-aware SDN cloud datacenters”, IEEE Communications Magazine, vol. 56, issue 2, pp. 1-26, Feb. 2018.
O-RAN Alliance, “O-RAN Fronthaul Working Group; Control, User and Synchronization Plane Specification”, ORAN-WG4.CUS.0-v01.00, Technical Specification, pp. 1-189, year 2019.
Vattikonda et al., “Practical TDMA for Datacenter Ethernet”, EuroSys conference, Bern, Switzerland, pp. 225-238, Apr. 10-13, 2012.
Ericsson AB et al., “Common Public Radio Interface: eCPRI Interface Specification”, V2.0, pp. 1-109, May 10, 2019.
Xilinx Inc., “Radio over Ethernet Framer v2.1”, PB056 (v2.1), pp. 1-9, Oct. 30, 2019.
Weibel, H., “High Precision Clock Synchronization according to IEEE 1588 Implementation and Performance Issues”, Zurich University of Applied Sciences, pp. 1-9, Jan. 17, 2005.
Sanchez-Palencia, J., “[RFC,v3,net-next,00/18] Time based packet transmission”, pp. 1-14, Mar. 7, 2018.
IEEE Std 802.1Qaz™, “IEEE Standard for Local and metropolitan area networks—Media Access Control (MAC) Bridges and Virtual Bridged Local Area Networks—Amendment 18: Enhanced Transmission Selection for Bandwidth Sharing Between Traffic Classes”, IEEE Computer Society, pp. 1-110, Sep. 30, 2011.
Crupnicoff et al., “Deploying Quality of Service and Congestion Control in InfiniBand-based Data Center Networks” White Paper, Mellanox Technologies Inc, Rev 1.0, pp. 1-19, Oct. 15, 2005.
Mathey et al., “Scalable Deadlock-Free Deterministic Minimal-Path Routing Engine for InfiniBand-Based Dragonfly Networks”, IEEE Transactions on Parallel and Distributed Systems, vol. 29, No. 1, pp. 183-197, Jan. 2018.
Wikipedia, Precision Time Protocol, pp. 1-9, Apr. 20, 2020.
SMPTE Standard, “Professional Media Over Managed IP Networks: Traffic Shaping and Delivery Timing for Video”, The Society of Motion Picture and Television Engineers, pp. 1-17, Nov. 22, 2017.
Wikipedia, “Time-Sensitive Networking”, pp. 1-12, Mar. 5, 2020.
Wikipedia, “Memory Protection,” pp. 1-6, last edited May 23, 2021.
Mills, “Network Time Protocol (NTP),” RFC 0958, pp. 2-15, Sep. 1985.
Mills, “Network Time Protocol (Version 1): Specification and Implementation,” RFC 1059, pp. 2-59, Jul. 1988.
Mills, “Internet Time Synchronization: The Network Time Protocol,” IEEE Transactions on Communication, vol. 39, No. 10, pp. 1482-1493, Oct. 1991.
Mills, “Network Time Protocol (Version 3): Specification, Implementation and Analysis,” RFC 1305, pp. 1-96, Mar. 1992.
Related Publications (1)
Number Date Country
20240089147 A1 Mar 2024 US
Provisional Applications (1)
Number Date Country
62809786 Feb 2019 US
Continuations (2)
Number Date Country
Parent 17495824 Oct 2021 US
Child 18513565 US
Parent 16789458 Feb 2020 US
Child 17495824 US