CA2228219C - Packet routing - Google Patents

Packet routing Download PDF

Info

Publication number
CA2228219C
CA2228219C CA002228219A CA2228219A CA2228219C CA 2228219 C CA2228219 C CA 2228219C CA 002228219 A CA002228219 A CA 002228219A CA 2228219 A CA2228219 A CA 2228219A CA 2228219 C CA2228219 C CA 2228219C
Authority
CA
Canada
Prior art keywords
packet
network
routing
node
destination
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CA002228219A
Other languages
French (fr)
Other versions
CA2228219A1 (en
Inventor
David Cotter
Martin Christopher Tatham
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
British Telecommunications PLC
Original Assignee
British Telecommunications PLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=26140349&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=CA2228219(C) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Priority claimed from GBGB9515536.2A external-priority patent/GB9515536D0/en
Application filed by British Telecommunications PLC filed Critical British Telecommunications PLC
Publication of CA2228219A1 publication Critical patent/CA2228219A1/en
Application granted granted Critical
Publication of CA2228219C publication Critical patent/CA2228219C/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/0001Selecting arrangements for multiplex systems using optical switching
    • H04Q11/0062Network aspects
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/02Topology update or discovery
    • H04L45/06Deflection routing, e.g. hot-potato routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L45/00Routing or path finding of packets in data switching networks
    • H04L45/34Source routing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/0001Selecting arrangements for multiplex systems using optical switching
    • H04Q11/0062Network aspects
    • H04Q11/0066Provisions for optical burst or packet networks
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/0001Selecting arrangements for multiplex systems using optical switching
    • H04Q11/0005Switch and router aspects
    • H04Q2011/0037Operation
    • H04Q2011/0041Optical control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q11/00Selecting arrangements for multiplex systems
    • H04Q11/0001Selecting arrangements for multiplex systems using optical switching
    • H04Q11/0062Network aspects
    • H04Q2011/009Topology aspects

Abstract

In a method of routing a packet carried on a network having a generally regular topology, the packet is received at a node (N) where a local routing decision is made. The packet is output in a direction selected according to the routing decision. The packet carries in addition to a destination address a directional flag indicating explicitly the preferred direction of onward travel and the routing decision is made using this flag. Several flags may be used, corresponding to different dimensions of the network.

Description

PACKET ROUT1N~C

The present invention relates ~o a method of routing packers on a netv~.~ork, and to networks and nodes adapted to implement the method.
Packet routing netuvorks may be used, for example, to interconnect the different processors of a :multi-processor ,:omouter, or as the basis of a LAN
interconnecting a number ov different computers. In the future, it is envisaged that such networks might be used for distributed processing applications such as the provision of shared virtual-reality environments - "virtual meeting places" -or for fast complex visualisation of data, for example in financial institutions.
Such a network might also be usec; for the internal architecture of a packet switch used, for example, in a telecommunications network.
All the examples discussed above will benefit from networks capable of operating at ultrafast speeds, e.g lOGBitls or more. To achieve such speeds, it is essential that there is efficient routing of packets to minimise transit times from source to destination and ~avithout the process cf making routing decisions itself providing a bottleneck. It has previously been proposed to use a class of techniques known as "self-routing", as described, for example, in the present applicant's copending international application W095 33324.
Self-routing is a method of namganon thorough a packet-switched network m which the onward route .at each node is determined locally v~~ithout consulting a network database in a centralised or distributed form (for a formal definition of self-routing, reference is made to the paper by Baransel et al cited below as reference [14]1. The routing decision is made based on information (usually the destination address) extracted from the packet header. In such a network, the time required to make a ror.ning decision must be no longer than the transmission time for a single packet. .f this condition is not observed the system becomes unstable since the ratio of t:he packet arrival rate to the service rate at a node can become greater than 1 , so that queue lengths can grow indefinitely. For high transmission speeds, or for short packet lengths, this stability criterion is more difficult to satisfy. It becomes a very sevare constraint in the case of ultra-high speed networks operating at multi-Gbit/s transmission rates, particularly when the transmission format uses fixed-length packets or cells of at most a few tens of bytes in length.
Assuming, for example, the 53-byte length of ATM cells and a peak bit rate of 100 Gbit/s [1 ], a node has only a few nanoseconds to perform the following tasks for each cell that arrives: select the appropriate output link on which the cell should be transmitted; and resolve contention. The situation can be alleviated by breaking these tasks into a number of separate procedures which are performed in pipe-line mode. Nevertheless it is essential for ultrafast networks that the procedures used for routing and contention resolution should be as simple as possible to minimise the processing time.
A further motivation for simplifying the routing and contention-resolution procedures in ultrafast networks is the technology limitations of photonic devices.
Recent experiments have demonstrated the potential for photonic networks to carry data at single-wavelength, single-channel rates approaching 100 Gbit/s and beyond [2]. In these networks the transmission bit-rate is higher that the speed capability of electronic devices. However, the procedures for routing involve combinations of processes at two distinct levels of granularity - the bit level and the packet level [~1 ]. For ultrafast networks, processes at the bit level require photonic devices with response times at least as fast as the bit period (picosecond scale), whereas processing at the packet level can be performed using high-speed electronics at the packet rate (nanosecond scale). Photonic logic devices are much less developed than electronic ones, they have primitive functionality and are relatively poorly integrated, power hungry and costly and are unlikely to achieve a comparable level of development for many years to come. Therefore a further requirement for uftrafast self-routing networks is that the number and complexity of bit-level processes should be reduced to the absolute minimum.
US patent 5105424 discloses one example of a routing scheme, intended for use within an integrated electronic massively parallel processor. The scheme involves determining at the source of a packet the entire path that the packet should follow from the source to the destination. The path is defined as a sequence of relative addresses and is added to the message packet in the form of a header. Routing is carried out by routing automata which are associated with the different computing nodes. The direction in which the packet is to be output is determined at the automata by referring to the relative address in the header, and the header is updated by deleting the parts that relate to the previous portion of the path. This has the disadvantage that the address has to be read, processed and modified at every node. This imposes a significant overhead of complex bit-s level processing. Also, since this approach does not allow for deflection from the predetermined path, deflection routing cannot be used. This makes it necessary for the nodes to include large buffers to resolve contention under conditions of heavy traffic load.
The paper by T Y Chung published in Phoenix Conference on Computers and Communications, March 1989, USA, pages 214-218, discloses a routing scheme which, like that in the US patent discussed above, fully determines the route of the packet at the source, and programs this route in the header of the packet. It differs however in that the route is determined using an numerical algorithm rather than from a look-up table at the source. But as in the above scheme, the intermediate routing nodes, termed in this paper "tandem nodes", simply read the routing information and act upon it, rather than making an autonomous routing decision. The approach adopted in this paper still requires that all the routing information coded into the packet header must be read bit-by-bit, updated, and the packet header must be overwritten with the updated routing information. Again, this amount of bit-level processing is a significant disadvantage in the context of the system intended to operate at high bit rates.
Although the paper makes reference to the possibility of deflection routing, the routing scheme, because of its deterministic nature, is not well adapted for such an approach. In this scheme, if deflection occurs, then the deflecting node has to recompute the routing information for the entire onward path leading to the packets destination, just as though the deflecting node which effects the deflection was itself the original source of the packet. Since these methods use predetermined routes encoded in the packet header, neither is a self-routing method.
SUMMARY OF THE INVENTION
According to, a first aspect of the present invention, there is provided a method of routing a packet carried on a network having a generally regular topology comprising:
(a) receiving a packet at a node;
(b) reading a destination address and a directional flag, both of which are carried with the packet, the directional flag indicating explicitly a preferred direction of onward travel for the packet;
(c) making a local routing decision according to the value of the directional flag; and (d) outputting the packet from the node in a direction selected in accordance with the routing decision.
The term "directional flag" as used herein denotes a simple unit of data which indicates a preferred direction of travel of a packet from its source to its destination without fully determining the path, that is the specific sequence of links and routing nodes followed by the packet, from the source of the packet to the destination. It may comprise just a single bit for each dimension of the network.
Correspondingly, the term "local routing decision" as used herein denotes a selection of output paths which is made locally at the routing node and which is not predetermined when the packet leaves its source.
The present invention provides a self-routing protocol with minimal processing overhead, yet that can provide a routing efficiency and network performance comparable to that of the most sophisticated routing mechanisms.
It uses an approach based on the concept of dead reckoning (self-navigation without the use of landmarks). This approach greatly reduces the total processing at network nodes, and also simplifies and minimises bit-level processes. Like random routing, another primitive protocol, dead reckoning is robust, tolerant of network irregularities and faults, is simple to implement and manage, and is readily scalable.
However, unlike random routing which is typically very inefficient, dead reckoning can provide good routing efficiency and network performance.
Preferably the packet is an optical packet carried on an optical network.
Although the method provides particular advantages in optical networks, especially where photonic devices are used, it is by no means limited to use with such networks. It also gives advantages when used, for example, with high-speed electronic networks, or with optical networks using electronic switching logic.
Preferably the network has at least two dimensions, and the packet carries at least two directional flags, one for each dimension of the network.
The network may comprise a mesh-connected array of nodes such as the Manhattan Street Network described in further detail below. The dead reckoning 5 method then makes use of the fact that the network has a regular or predominantly regular layout. For example, in a regular rectangular mesh network with rows and columns associated with the principal axes of the compass, a packet may have knowledge that its destination is located north and east. The packet self-navigates through the network by choosing whenever possible to travel in a direction that leads broadly towards the destination. When the packet encounters a routing node, it simply instructs the node as to the preferred direction of onward travel: the node does not compute an optimum direction. The main tasks for the node are merely to check whether the packet's destination address matches that of the node either wholly or in part, and to resolve contention.
According to a second aspect of the present invention there is provided a node for routing packets carried on a generally regular network, the node comprising:
a) an input for receiving a packet;
b) a routing decision unit for making a local routing decision using information carried by the packet, the routing decision unit including means responsive to a directional flag carried by the packet and indicating explicitly a preferred direction of onward travel;
c) a plurality of outputs for directing the packet onto the network in different respective directions; and d) means for directing a packet to different respective ones of the plurality of outputs depending on an output of the routing decision unit.
According to a third aspect of the present invention there is provided a network having a generally regular topology and including a plurality of nodes in accordance with the second aspect of the invention.
According to a fourth aspect of the present invention, there is provided a computer system comprising a plurality of processors interconnected by a network in accordance with the third aspect of the invention.
QESCRIPT10N OF THE DRA'~IINCS
Systems embodying the invention in its different aspects will now be described in further detail, by way of example only, and contrasted with the prior art, with reference to the accompanying drawings, in which:
Figure 1 is a flow diagram illustrating the logic of a self-routing protocol implementing the present invention;
Figure 2 shows a 16-node Manhattan Street Network;
Figure 3 is a graph showing routing efficiency using dead reckoning in MS-Nets of size n x n, versus network dimension n;
Figure 4 is a schematic showing the structure of one of the nodes of Figure 2;
Figure 5 is a graph showing the hop probability distribution for routing using the dead-reckoning protocol in an 8 x 8 MS Net with no buffers for various values of the probability of packet insertion in a free slot, 0.003 to 0.99;
Figure 6 is a graph showing the fraction of packet deflections for an 8 x 8 MS Net embodying the present invention as a function of the probability of packet insertion in a free slot;
Figure 7 is a graph showing relative throughput of an 8 x 8 MS-Net embodying the present invention as a function of the probability of packet insertion in a free slot;
Figure 8 is a graph showing the relative throughput of an 8 x 8 MS-Net using shortest-path routing as a function of the probability of packet insertion in a free slot;
Figure 9 is a graph showing the mean number of packet hops for an 8 x 8 MS-Net embodying the present invention as a function of the probability of packet insertion in a free slot;
Figure 10 shows a network embodying the present invention used as a LAN interconnecting a number of computers;
Figure 11 shows a network embodying the present invention in use as a WAN to interconnect a number of LANs;
Figure 12 is a schematic showing a network embodying the present invention used as the backbone of a multiprocessor computer system;
Figure 13 shows a buffered N x N packet switch;
Figure 14 shows an ultra fast packet network embodying the present invention used as the internal architecture of a packet switch;
Figure 15 shows an alternative network topology used in a system embodying the present invention;
Figure 16 is a detailed schematic of the processing stages in a node;
Figure 1 7 shows the optical layout of a node;
Figure 18 illustrates the orientation of a cross-point switch with respect to the row and common directions;
Figure 19 shows a routing logic processor;
Figure 20 shows a contention-resolution logic processor;
Figure 21 shows the structure of a network time slot;
Figure 22 shows the sub-division of the switchband;
Figure 23 shows the structure of circuits on the input to the access switch; and, Figure 24 shows circuits for insertion of signals into a packet leaving the node.
DESCRIPTION OF EXAMPLES
As shown ~in Figure 2, an optical network 1 comprises a plurality of nodes N interconnected in a regular mesh pattern. In the example shown in Figure 2, a Manhattan Street Network (MS-Net) topology is used. This is a two-connected, regular network with unidirectional links. There is an even number of rows and columns with two links arriving and two links leaving each node N. Logically, the links form a grid on the surface of a torus, with links in adjacent rows or columns travelling in opposite directions. Figure 2 shows a 16-node (4x4) MS-Net.
Figure 4 shows the structure of an individual node N. It incorporates a switch 2 which is set to route an incoming packet either to the node's row output O~, to the column output O~ or to the host local to the node. This host may, for example, be one of a number of processors connected to respective nodes and forming in combination a multi-processor parallel processing computer system.
The switch 2 also has an input from the host so that. when appropriate, the node can insert a packet from the local host onto the network.
The switch is set using a novel routing scheme illustrated in Figure 1 and termed by the present inventors "dead reckoning". This method of operating the node is described in further detail below. Circuits implementing this method are also described below with reference to Figures 16 to 20, and examples of _ appropriate components are identified in the section below headed "Implementing Technologies".
Dead Reckoning In the traditional approach to self-routing, each packet carries its destination address in the header. At each network node encountered by the packet along its route, the destination address is read and this information is used to compute the optimum path for onward transmission. Typically the routing algorithm is made tractable by using a sequential arithmetic addressing scheme for the nodes which reflects the regularity of the network topology.
The dead-reckoning approach introduced here also relies on the network having a regular (or mainly regular) structure. In the layout of the logical interconnections, the links connecting nodes are oriented parallel to the principal axes of the topology. In this case, in addition to the destination address, each packet carries some elementary information about the general direction of its destination. For example, in a two-dimensional rectangular grid network with rows and columns associated with the principal axes of the compass, a packet may have knowledge that its destination is located somewhere 'north and east'. The packet self-navigates through the network by choosing, whenever possible, to travel in a direction that leads broadly towards the destination. When the packet encounters a routing node, it simply instructs the node as to the preferred direction of onward travel; the node does not compute an optimum direction. As noted above, the main tasks for the node are merely to check whether the packet's destination address matches that of the node either wholly or in part, and to resolve contention.
The logical function of a routing node using dead reckoning is summarised in Figure 1. The bit-level process of detecting a match between corresponding fields in the packet destination address and the node address can be performed very efficiently using an elementary single-step operation with ultrafast photonic devices [3-5], without the need to read and process the full destination address bit-by-bit.
When a packet is first placed on the network, a look-up table or shortest-path algorithm is used to determine the directional bearings towards the destination node, and this information is coded into the packet header, together with the destination address. The algorithm or look-up procedure has to operate only at the relatively slow access rate of the local host. The place from which a new packet starts out is the only point in the network where the packet has access to this routing information. The necessary amount of directional information that each packet must carry can be very small: just one bit for each principal axis of the network topology. For example, as described in the following section, the directional information is only 2 bits in the case of a Manhattan Street Network (MS-Net). This directional information is carried by the packet across the network to its destination, and is modified only occasionally during the journey.
The information may be modified when the packet encounters a routing node whose address contains a field that correctly matches the corresponding field of 1 5 the packet destination address (e.g. in a MS-Net when the routing node is situated in the same row or column as the packet destination). The destination is found when the two addresses are wholly matched.
Manhattan Street Networks The dead-reckoning approach is now described in more detail in the context of the well-known MS-Net (6-8], which, as described above, is a two-connected, regular network with unidirectional links. The attractive features of this network stem from its rich connectivity. The MS-Net is well suited to a simple deflection strategy for contention resolution. It performs well under high loading with no buffers ('hot potato' routing) or a small number of buffers [8,91.
This is an especially useful feature for ultrafast photonic networks, in which technological limitations constrain practical buffer depths to small values [
1 O]. The rich connectivity also makes for a robust network, able to survive multiple link failures.
In the MS-Net a routing decision must be made at every node encountered by a packet. Maxemchuk [7] describes various deterministic routing rules that operate with excellent efficiency.
These rules make use of the regular structure of the network, and depend on an addressing scheme that names rows and columns in monotonic arithmetic sequences. The drawback of these routing rules is the need to read the full destination address and perform several computations of various complexity for every packet at every routing node.
Dead-reckoning routing rules 5 In the dead-reckoning approach, each packet finds a path through the network by following directional bearings towards the destination. The destination is located at the intersection of the 'destination row' and the 'destination column' in the network mesh. At the place at which the packet is first inserted into the network, it is given two initial bearings relative to the principal axes of the network 10 layout to indicate the shortest path towards the .destination. These 'destination bearings' can be represented by a single 2-bit word, one bit for each of the principal axes. A convenient shorthand is to designate the logical orientation of columns in the MS-Net as 'north-south', and rows are oriented 'east-west'.
(Notice however that in the toroidal topology of a MS-Net, the north-south directional orientation is regular and continuous, unlike the north-south latitude of a globe which has singularities at the poles.) Therefore a suitable set of destination bearings for a packet might be 'north and east'. The destination bearings are carried by the packet on its journey through the network, and at each node of the network where a routing decision is required the routing preference is selected according to this simple rule:
a) A packet should, if possible, travel in the direction of one of its destination bearings. If two or no such directions are available, the packet does not care which path is selected (except in case b or c below).
The destination bearings are modified only in the particular circumstances now described. At each node the destination address is compared with the row and column names of the node address to see whether the destination row or column has been located (and obviously if both row and column addresses match, then the destination is found.) Supplementary routing rules apply when a packet has located its destination row or column:
b) If a packet encounters its destination row (column), and if that row (column) is oriented in the direction of one of the destination bearings, then the .
packet should turn into it if possible, otherwise proceed as in the main rule a.
c) If a packet is travelling along its destination row or column in the direction of one of the destination bearings, it should continue in that direction if possible, otherwise proceed as in the main rule a.
d) If a packet crosses over its destination row (column), then the north-south feast-west) destination bearing for the packet must be checked and reset if necessary.
e) If a packet is travelling along its destination row (column), whether or not in the direction of a destination bearing , and then a turn is made, the north-south (east-west) destination bearing must be checked and reset if necessary.
These simple routing rules provide a basis on which a packet may select its onward path at each crosspoint with good efficiency. A routing logic processor having the task of executing these rules requires just 4 bits of information for each packet: i) the destination bearings (2 bits); ii) whether or not the destination row (column) matches the node row (column) (1 bit each). Using these 4 input bits, the routing logic is sufficiently simple that the rules can be executed with hard-wired electronic circuitry using a small number of elementary Boolean logic gates, without the need for arithmetic, registers or look-up tables. This logic circuit can be designed with several parallel strands, and the maximum length of any strand is about 4 gates. The routing logic processor can therefore operate at high speed, allowing the optimum path to be determined at a rate suitable for self-routing in multi-Gbit/s networks.
Because the network is isotropic, the routing instructions are common to every crosspoint in the network. An important difference between the dead reckoning approach and existing routing schemes is that dead reckoning does not require the network rows and columns to be named in any organised fashion;
they can be named in an entirely arbitrary way since the routing does not rely on node addresses being arranged in a particular sequence.
Routing efficiency A comparison of the routing efficiencies obtained using dead reckoning, random routing, and more sophisticated routing schemes is presented in Table I
for various sizes of MS-Net. It is assumed here that there is no congestion (contention resolution is considered in following sections), and that packets follow the routing rules exactly. Where a rule indicates that there is no preference between the two outgoing links from a node, one of the paths is selected at random with probability 0.5. The average distance between nodes (in terms of the number of hops) for each routing scheme is calculated by determining the average distance between each source and destination in the network. The efficiency of a routing scheme is the average shortest path between nodes divided by the average distance between nodes using the routing scheme. In the case of the dead-reckoning routing scheme, a shortest-path algorithm (based on Maxemchuk's Deterministic Rule 1 [7]) is used once only to select the first output link from the source and also to determine the initial destination bearings.
Figure 3 shows the variation of the routing efficiency with dead reckoning in MS-Nets of size NxN, with N=4 to 64 (16 to 4096 nodes). For networks larger than 8x8, the efficiency is slowly varying with network size and is always greater than 87%.
Table I shows that the level of efficiency with dead reckoning is comparable to the efficiency that can be obtained using a sophisticated shortest-path routing algorithm at each node. However the dead reckoning approach is much simpler: it avoids the need to read the full packet-destination address and compute data such as the relative address of a node, its quadrant and the direction of the links emanating from the nodes. This is a very significant advantage for ultrafast networks.
Node structure The network carries fixed-length packets, and it is slotted so that any given link may carry at most one packet in each time slot. The structure of a node in this network is shown in Figure 4 (7]. Packets arriving on the two input links (one from a row and one from a column) are given a suitable relative delay so that the time slots are aligned at the routing switch [11]. In each time slot the node will accept up to two packets from the network for forwarding. If a packet is recognised as having reached its destination it is dropped from the network and diverted to the local host. Simultaneously, or if an empty time slot is detected on an incoming link, a packet may be accepted from the local host and inserted into the network. All the packets that enter the routing switch (whether received from the network for forwarding or inserted from the local host) are routed to one of the outgoing links according to the rules of the dead-reckoning scheme, following the preferences indicated by the 'destination bearings' where possible.
The nodes have output buffers on both ports able to hold a small number of packets (K=0 to 64). Depending on the buffer size, the node can employ a 'hot-potato' strategy (K =0) or deflection-routing strategy (K > 0) to resolve the contention that can arise if two packets indicate a preference to travel outwards on the same link f6]. In the event of contention, both packets are directed to the chosen output buffer provided there is at least one buffer slot available, with the 1 O order of the two packets chosen randomly. However, if there is no available buffer space, then one of the two packets (chosen at random) is deflected to the other output port. When two packets are present at the routing switch and one of them has no particular outward routing preference, then that packet will be the candidate for deflection. When a packet has no particular outward routing 1 5 preference and there are no other constraints, the packet will be assigned to either output port chosen at random.
There are two simple strategies that can be used to deal with new packets that the host wishes to have inserted into the network. One strategy is to hold packets in the source buffer until their preferred output port becomes available; an 20 alternative is to insert packets into the network immediately any output link or buffer becomes available. We choose the latter strategy here. Therefore it is assumed that if there are f available time slots where f = 0, 1 or 2 (i.e. 2-f packets are received from the network for forwarding), then f new packets may be inserted from the host, irrespective of whether their preferred output port is available 25 (i.e.packets may incur a deflection at their source node). To cater for this, the shortest-path algorithm or look-up table at the source should provide two sets of destination bearings for each new packet: one set will be used if the packet is forwarded to its preferred output port at the source node, whilst the other set will . be used if the packet is deflected to the other port. The destination bearings are 30 chosen so that the new packet wilt find the shortest available path from the given output port of the source node to the destination, assuming there are no further deflections. This strategy has the advantage that, on average, a new packet spends less time in the access queue, but the disadvantage that if the packet is deflected at the source node the shortest available path from the non-preferred output port may contain more hops. We use a shortest-path algorithm based on _ Maxemchuk's Deterministic Rule 1 (7] to select the preferred output link from the source and also to determine the initial destination bearings to be used with and without deflection at the source node.
Network performance It can be expected that the dead-reckoning scheme for self-routing will be degraded when the network is heavily loaded because a packet may be deflected to a position where the destination bearings it carries no longer lead to the destination by the shortest route. To investigate this, we have simulated the performance of a 64-node (8x8) MS-Net as a function of the traffic load. The generation of new packets at each node is memoryless, and the mean rate of packet generation at each node is the same. The choice of destination nodes follows a uniform distribution, and the insertion and routing of new packets is 1 5 independent of the state of the output buffers in the network nodes.
Figure 5 shows the probability distribution of the number of hops used between source and destination, for various levels of the offered load, with hot-potato deflection (K = O). The offered load is represented by P", the probability that a source will insert a new packet into a free time slot. The exponential decrease in hop probability versus number of hops, even for PA as high as 0.99, demonstrates the reliability of the dead-reckoning routing protocol; we have detected no tendency for packets to become trapped or loop indefinitely. This confirms that although the effect of deflections is to increase the number of hops, deflections do not endanger the integrity of the dead-reckoning method. The integrity of the scheme is guaranteed for the MS-Net by the regular, cyclic topography of the network. Figure 6 shows the fraction of packet deflections as a function of PA, for various buffer sizes. The maximum fraction of deflections, even with no buffers, is only 12.2%, because of the large number of packets that enter nodes without caring which output link is selected. _ A crucial measure of network efficiency is the throughput. In steady state, the rate at which packets are accepted from the source by the network should equal the rate at which the network delivers packets to the destination.
The steady-state throughput is therefore the average number of packets delivered per node per time slot. The theoretical maximum throughput for the MS-Net (the maximum store-and-forward throughput with shortest-path routing) is 2 divided by the average shortest path in terms of the number of hops [8]. For the 8x8 MS-Net, this maximum throughput is 2/5.02 = 0.399. It is useful to define the 5 relative throughput as the actual throughput normalised by the theoretical maximum. This normalisation compensates for the dependence of the actual throughput on network size, and provides an indication of how much of the maximum possible throughput is being achieved [8]. Figure 7 shows the relative throughput versus PA for various buffer sizes. With hot-potato deflection (K
=01, a 1 O relative throughput of 43 % is obtained at maximum network load, and this increases to 79% with a buffer depth K=4. This performance obtained using the primitive dead-reckoning approach compares quite well with the performance of the same 8x8 MS-Net using a shortest-path algorithm for routing every packet at every node, as shown in Figure 8 [8, 9]. In that case, a relative throughput of 15 55°!° is obtained with hot-potation deflection at maximum network load, increasing to 91 % with a buffer depth K =4. The conclusion is that the price paid for the simplicity of using dead reckoning is only a modest decrease in relative throughput.
Moreover, since the amount of processing needed at the nodes for dead reckoning is minimised, the network can sustain operation at much higher speed by using photonic devices (for example, packet header address matching at 100 Gbit/s line rate has been demonstrated recently [5]). Therefore, despite the modest reduction in relative throughput, a substantial gain in the absolute network throughput in terms of information delivered per second can be achieved.
Another important performance metric is delay. The total delay consists of two parts: the time that a packet must wait in the host buffer before being inserted into the network, and the network delay itself (the time for a packet to traverse the network from source to destination). Here we consider only the latter aspect. The network delay introduced by each hop is the sum of three components: the propagation delay, the delay deliberately introduced at the node to align time slots (Figure 4), and the queuing delay in the output buffers.
The inventors have found that in an ultrafast photonic network the dominant component is the propagation delay. This is because the time for transmission of a single packet is small. For example, as mentioned in the introduction, the time slot required to accommodate a 53-byte ATM cell at 100 Gbit/s with time guard bands and other overheads is around 6.5 ns [ 1 ], or equivalently a distance of only 1 .3 m in optical fibre. Therefore for an average link length greater than a few tens of metres, and assuming that practical photonic buffers are limited to a few time slots in depth ( 10], the propagation time far exceeds the other components of delay. It follows, assuming the link lengths are similar, that it is important to minimise the number of hops that a packet must take in travelling from source to destination.
Figure 9 shows the mean number of hops as a function of P,, in the 8x8 MS-Net using the dead-reckoning protocol, for various buffer sizes. Also shown on the right-hand scale is the 'relative latency', defined as the mean number of hops normalised to the average shortest path (5.02 hops in this case). This shows that a buffer depth of 4 is sufficient to reduce the propagation delay to within 30% of the theoretical minimum.
As already mentioned, the MS-Net architecture has well-known attractive features that stem from its rich connectivity. It performs well under high loading and is able to survive multiple link failures. However, it has also been criticised in several ways: it does not support multicasting; it is said not to support a guaranteed service; and the network permits packets to be reordered [ 1 2].
These are criticisms that are less significant in the case of ultrafast photonic networks.
First, multicasting in the MS-Net must be performed using higher-level protocols (efficient strategies are being developed currently [ 13]), but effective replication of the payload is very simple in the optical domain using passive splitting devices.
Second, it is true that certain traffic patterns will produce many deflections, causing the MS-Net to send some packets over many additional hops. However since the network latency is very small, dominated by propagation delay, this may not be an important consideration for connectionless data, or even for traditional delay-sensitive connection-oriented applications such as voice and video.
Third, it is a debatable point as to whether the reordering of packets is a significant drawback. It has been suggested that for many foreseeable applications, packet reordering is either not required in real time, or can be achieved in real time using a reassembly buffer of modest size [14].
In ultrafast photonic networks using picosecond optical pulses for transmission the most practical approach is to allow packets (including the destination address and other header data) to propagate through the network without modification in transit and without opto-electronic regeneration. This avoids opto-electronic bottlenecks, and also avoids the need for ultra-short laser sources and clock-recovery mechanisms with picosecond precision embedded in the network [1]. However the dead-reckoning technique relies on each packet carrying some additional elementary information about the general direction of its destination, and this information may be modified occasionally during the packet's journey from source to destination. The necessary amount of information carried by each packet can be very small: just 2 bits in the case of the MS-Net that we have described in detail. The rate of this information (2 bits per packet time slot) is slow enough that it can be easily communicated on a link-by-link basis using a channel that is out-of-band for the remainder of the packet. It is unnecessary for this signalling information to be carried in the same ultrafast format as the remainder of the packet header and payload. It could be carried on a separate wavelength, in a separate time segment, or on a physically-separated parallel channel, provided always that packet-level synchronism is maintained across each link.
Several additional advantages of the dead-reckoning scheme have been identified. The naming of rows and columns in the network can be arbitrary;
there is no need to follow an organised sequential scheme for assigning addresses.
It is not even necessary for the nodes to know the dimensions of the network. This means that additional rows and columns can be introduced into the network at any position and at any time, without the need for alterations or adjustments to the existing network (apart from updating the look-up tables or shortest-path algorithms used at the sources). Special schemes for introducing rows and columns, such as fractional addressing [7), are not required. Since the basic routing rules may be executed in hard-wired electronic logic circuitry for speed, this is a considerable advantage. This also greatly simplifies the processes of planning, evolution and management of the network.
The dead-reckoning scheme is tolerant of network irregularities. If nodes and links are added or fail in a perverse fashion, then locally the network may bear little resemblance to the regular structure. Whereas deterministic routing rules based on regular, sequential arithmetic addressing may fail in these circumstances, the dead-reckoning scheme appears to have good survival, although the routing efficiency is degraded. As described, our simulations for a MS-Net have shown that the dead-reckoning scheme is robust to deflections, even under very heavy load. We also note that the scheme is robust to the accidental corruption of the 'destination bearings' data carried by a packet. These robust features are guaranteed in a network such as the MS-Net which has a regular, cyclic topography. In other words, if the packet is deflected far from its preferred path, or if the destination bearings become lost or corrupted en route, the packet will continue in a non-optimum direction and so lengthen its journey. But because the network is cyclic, the packet will eventually encounter its destination row and column, and the protocol ensures that correct bearings are then automatically re-established. Although less efficient, dead reckoning can also be implemented in 1 5 a non-cyclic network with boundaries. In this case the nodes at a boundary should 'reflect' packets from the boundary, whilst reversing one or more of the destination bearings if necessary.
Ultrafast photonic networks capable of interconnecting processors and workstations at multi-Gbit/s speeds are becoming a practical reality [ 1 , 3, 1 5, 16].
Significant progress has been made recently with the first demonstrations of the generation of photonic packets at 100 Gbit/s peak rate [1 ], address recognition [5, 17], and bit-level self-synchronisation techniques [18]. The dead-reckoning approach described here allows these recent technical advances in photonics to be applied in ultrafast mesh networks using optical self-routing, with massive throughput and speed.
Applications of ultrafast packet interconnection network These applications are described by way of example only, many other uses of the routing method, node and networks of the present invention are possible.
This description assumes that the network is of the Manhattan Street type, which is the example discussed in detail in above. Therefore it is assumed that the nodes are 2-connected (2 input lines and 2 output fines at each node].
The applications of the network depend simply on the type of hosts that are connected and the geographical extent of the network.
1. Direct interconnection of computers and workstations (Figure 10) e.g. office/campus LAN of supercomputers/'high-end' users;
e.g. distributed processing applications (examples: high quality synthetic environments - 'virtual meeting place', fast complex visualisation of data in a financial institution);
2. High speed interconnection of LANs (Figure 1 1 ) In this case the hosts for the nodes of the ultrafast packet network are routers providing an interface with conventional lower-speed networks;
3. Mixture of 1 and 2 4. Ultrafast packet network used as the 'backbone' in the internal architecture of a large computer (Figure 12).
In this case the hosts for the nodes of the ultrafast packet network are sub-systems of the computer (processors, memory, I/O devices, and so on);
5. Ultrafast packet network used as the internal architecture of a packet switch (e.g. for very high capacity ATM) (Figures 13, 14).
In this case the nodes serve the input and output ports of the packet switch. Figure 1 3~ shows a buffered NxN packet switch (N input ports, N
output ports), in which the input traffic is buffered.
In the switch design using the ultrafast packet network as a switch, the deep input buffers on the input ports are retained. If the network uses deflection routing (as in the example of the Manhattan Street Network, there may be small output buffers in the routing nodes. In that case the packet switch could be described as having both input buffers and 'internal' buffers (i.e. output buffers on the nodes of the switching network act together as buffers that are internal to the packet switch as a whole). If 'hot potato' routing is used (i.e. no output buffers on the switching nodest, then the packet switch as a whole has input buffers only.
Figure 14 shows the structure of the packet switch.
Alternative Topologies Although described above in relation to a MS-Net, the present invention is applicable to a wide range of different network topologies. For example the method can be used with the topology known as "triangularly arranged connection network" (TAC), first described by G E Myers and M E Zarki ("Routing in TAC:

Triangularly Arranged Connection Networks", Proc. INFOCOM'90, pp.481-486 (1991)). TAC is a three-connected toroidal mesh in which nodes are located on _ the vertices of equilateral triangles. The Figure 1 5 shows an example of a 16-node 4x4 TAC network. The number of nodes needs to be a multiple of 4 in order for 5 the links to be oriented properly. Myers and Zarki describe a self-routing scheme that is similar to the MS-Net scheme of Maxemchuk, in that each node computes the optimum outward link for each incoming packet using as data the packet destination address (which must be read in full) and the address of the current node.
10 The alternative is a dead reckoning scheme as follows: The principal axes of the network are as shown in the Figure, and are labelled x, y and z.. Every link forms part of a line of links (called a row) that runs parallel to one of the principal axes (similar to the streets and avenues of the MS-Net). The address of every node has 3 fields (each field corresponds to the name of the row of links parallel to a 15 principal axis). The destination of a packet is located at the intersection of three named rows of links, and has the address (DX,DY,DZ). Each packet carries a set of destination bearings with respect to the principal axes. The destination bearings are represented by~ a 3-bit word. The routing rules for dead reckoning in the TAC
are as follows. The current routing node has the address (NxNYNz).
20 a) A packet should, if possible, travel in the direction of one of its destination bearings. If two such directions are available, the packet does not care which of these two is selected (except in case b or c below). If three or no such directions are available, the packet does not care which path is selected (except in case b or c below).
The destination bearings are modified only in the particular circumstances now described. At each node the destination address is compared with the node address to see if DX = Nx, DY = NY, or DZ = NZ, indicating that the packet has found a row of links on which the destination is located (and obviously if all three matching conditions are discovered to be true, then the destination has been found).
Supplementary routing rules apply when one or two of the matching conditions are discovered to be true. , b) If a packet encounters a row of links on which the destination is located, and if that row of links bears towards the destination, then the packet should turn into it if possible, otherwise proceed as in the main rule a. c) If a packet is travelling along a row of links on which the destination is located, and is travelling in a direction that bears towards the destination, it should continue in that direction if possible, otherwise proceed as in the main rule a.
d) If a packet crosses over a row of links on which the destination is located, then the destination bearing for the packet must be checked and reset if necessary.
e) If a packet is travelling along a row of links on which the destination is located, whether or not in a direction that bears towards the destination, and then a turn is made, the destination bearings must be checked and reset if necessary.
Implementing Technologies 1 . Logical operation of a node Diagrams showing i) the logical function of a routing node using the 'dead reckoning' self-routing protocol, and ii) structure of a node, are shown in Figures 1 1 5 and 4 discussed above. A more detailed diagram showing the layout of processing stages in a node is given here in Figure 16. More details about the operation of these various stages is given below.
2. Optical connections for a node The optical layout of a node is given in Figure 17. If this is compared with Figure 4, the general switch symbol has been replaced by three 2x2 optical switches (two 'access switches' and one 'crosspoint routing switch'). Suitable routing switches would be lithium niobate devices such as type Y-35-8772-02 supplied by GEC
Advanced Components. The delay units shown in Figure 17 could be, for example, the tunable optical delay system described by P R Prucnal (IEEE J
Quantum Electronics, vol 29, no 2, pp. 600-612, 1993). The optical buffers can be of the type described by D K Hunter and I Andonovic (Electronics Letters, vol 29, no 3, pp. 280-281 , 1 993), in which the 2x2 switches could be the lithium niobate devices specified above, and the delay lines would be appropriately-cut lengths of optical fibre.
3. Routing Logic Processor " The routing logic processors determine the optimum onward routing for a cell, based on the routing rules stated earlier. Routing requests are received by the contention resolution processor from each of the routing logic processors on behalf of incoming cells. If a time slot on one of the incoming routes is vacant, then no routing request is issued by the corresponding routing logic processor. A
routing request for a cell contains the following information: i1 the requested outgoing path (row, column or don't care); ii) the destination bearings to be carried onwards by the cell if the requested crosspoint switch setting is granted; iii) the destination bearings to be carried onwards by the cell if the requested crosspoint switch setting is not granted (i.e. the cell is deflected). Usually the destination bearings carried by a particular cell are unchanged as the cell passes through a network node, whether or not the cell is deflected. However the routing rules define occasions when the destination bearings must be adjusted, and these are indicated in the detailed routing logic tables set out later.
The input to the routing logic consists of just 4 bits: does the cell's destination row address match the row address of the node? (1 bit); does the cell's destination column address match the column address of the node? (1 bit);
the orientation of the east-west destination bearing ( 1 bit); and the orientation of the north-south destination bearing (1 bit).
A new cell to be inserted into the network from the local host is placed in a first-in first-out (~F1F0) buffer and awaits a vacant network time slot. A
vacant slot can arise when there is a vacancy in the incoming traffic, or when an incoming cell has been identified as having reached its destination and is switched through to the local host. The routing look-up table provides an appropriate routing request for each new cell starting out on its journey across the network. The entries in the look-up table can be determined using, for example, a shortest-path algorithm.
Notice that only new cells consult the look-up tableahe table is not required for cells in transit through the node, which represent the bulk of the traffic.
Also the look-up procedure need operate only at the relatively slow access rate of the local host. The format of the routing request from the look-up table depends on whether the new cell is to be held in the buffer until a time-slot vacancy is available on the optimum outward path (assuming one of the two outward paths is actually preferred). If that is the case, the routing request comprises only the requested outgoing path (row or column) and the outgoing 'destination bearings'.
If, however, the new cell is to be launched out into the network just as soon as a vacant time slot becomes available on an input port of the routing switch, the look-up table must provide the full 3-item routing request described earlier.
In other words, in this case the routing request must provide the appropriate outgoing destination bearings for the new cell to use if it finds itself unable to exit by the preferred path.
The tables below show the detailed routing logic for network nodes in the various configurations of row and column directions. In effect, these tables show the mapping from the 4-bit input data to the output routing requests, based on the routing rules stated earlier. For the purpose of the tables showing the detailed routing logic, it is assumed that the 2x2 'cross-bar' routing switches at the crosspoints of the network are configured so that the 'bar' state is the straight-through direction for cells travelling in both the row and column directions, and the 'cross' switch state causes a change of direction. For example, Figure shows a crosspoint oriented with the row direction running from west to east and the column direction from south to north.
Based on Table 1 (i), Figure 19 shows a circuit diagram for the routing logic processor in a crosspoint oriented west to east and south to north, for cells incoming from the west. This detailed diagram confirms that the routing logic for dead reckoning, using the 4 input bits referred to earlier, is sufficiently simple that the routing rules can be executed with hard-wired electronic circuitry using a small number of elementary Boolean logic gates (invert, AND and OR), without the need for arithmetic, registers, or look-up tables. As shown, the logic circuit can be constructed with several parallel strands, and the maximum length of any strand is about 4 gates. Therefore, using ultra-high speed emitter-coupled logic devices that have very low rise and fall times ( < 0.2 ns) and low propagation delays ( <
0.6 ns), the routing logic processor can operate at high speed, producing routing requests within a small number of nanoseconds. Suitable devices are the SST ECL Logic IC
family (SEL1C) manufactured by NTT Electronics Technology Corporation. Part numbers are NLB6201 (quad 3-input OR/NOR gates); NLB6203 (quad 3-input AND/NAND gates); NLB6200 (quint 2-input OR/NOR gates). The latter of these could be configured as invertors for the circuits shown in Figures 1 9 and 20.
4. Contention resolution processor The contention resolution processor examines the various routing requests and determines whether two cells are expressing preferences for the same output port of the crosspoint routing s~r~itch. A suitable contention resolution pre c:edure is described above. In this case the contention resolution procedure is simple and can be implemented by bar d wiring using a srnali number of electronic logic gates.
As an example, Figure 20 sho~NS the circuit dagram to execute the main task of ., the contention resolution logic processor, which is to give tile command to the crossbar routing sv~ritch (and it is assumed here that 'hot potato' routing -i.e. nc output buffers- is used). f=or high speed operation, the electronic logic:
devices used could be the same as those specife:~ above fcr the routing logic processor (SST ECL Logic IC family (SELIC) manufactured by NTT Electronics Technology Corporation). If deflection routing with :utput buffers is used, then the logic circuit would be slightly snore complicated: there would be two additional data inputs, each indicating whether one of the output buffers is full. In acldition to setting the access and crosspoint routing switches, the contention resolution processor has the task of issuing the appropriate destination bearings for onward 1 5 transmission. The logic cir c:uit for this task is not shown in Figure 20, but is very simple. For each of the two packets currently being routed, the destination bearings are taken directly from the outputs G,H or J,K from the rouging logic processors (Figure ~ 1 91, depending on whether the routing request for each packet is granted or declined.
If required, a priority scheme could be introduced. There are many such schemes to choose from, most of which will reqmre additional network signalling to represent the status of individual cells, for example: latency-sensitivity;
age and time-to-live stamping; 'destination-in-sight' flag; service grade; etc. The value of these priority schemes must be judged against the additional overheads of complexity, transmission and processing time, which will tend to limit the overall network throughput. Schemes not requiring any additional network signalling include prioritisation (priority granted or declined) for new cells waiting in the access buffer.
5. Header address matching The task of seein~;3 whether there is a match between a field in the packet destination address and a corresponding field in the address of the routing node could be performed at ultr afast speed using the binary ward recognition technique described in international patent application W094 21088, with further 2u technical details disclosed in W095 33324 page 15 line 22 - page 17 line 2. An experimental demonstration of this technique is described by D Cotter, J K
Lucek, M Shabeer, K Smith, D C Rogers, D Nesset and P Gunning ("Self-routing of 100 Gbits/s packets using 6-bit address recognition", Electronics Letters, in press).
6. Arrangements for communicating the destination bearings As already described, various vvay=. of communicating the destination bearings are possible anc~ the necessary amount of information ca«ied by each packet can be very small: just 2 bits in the case of the MS-Net.
A way of communicating the destination bearings using a separate time segment is now described.
Figure 21 shows an example of a network time slot. In this slot we combine localised fine-grain (bit-level) timing extraction on a packet-by-packet basis together with global ccarse-grad (packet-level) timing. This; diagram illustrates the relationship between the bit-level and packet-level time references.
The network clock provides only coarse network synchronisation at the packet level. The network is thus; slotted in time and space, at the clock frequency, with , a maximum of one cell occupying each slot. In the example shown in I=figure 21 , the time partitioning within the time slot has been dimensioned to accommodate standard ATM cells. The network clock has been chosen to be one of the standard SDH rates. The cell consists of a burst of ultrashort optical pulses representing about 440 bits fthe 53-byte ATM cell plus around 10-20 additional header bits to allow routing of the cell in the ultr afast optical packet network) at an instantaneous rate of 100 Gbit/s. Notice that the position of the cell within its time slot is not defined with bit-level precision; instead there is a timing tolerance equal to several bit periods (around 100 picoseconds or 10 bit periods in this example). The network time slot also contains a switch band, allowing time for the reconfiguration of routing switches, and time guard bands. It is necessary for this switch band to be equivalent to many bit periods. For example, typical routing switches (lithium niobate devices such as type Y-35-8772-02 supplied by GEC
Advanced Components, or 2x2 integrated InP semiconductor of the type described by G Sherlock et al in Electronics Letters 30, 137-138, 1994) are capable of switching configuration in a time of -- 1 ns. Therefore for cells with an instantaneous bit rate of 100 Gbit/s, a 1 ns switch band is equivalent to 100 bit periods. The 1 ns-wide 'switch band' allows time for the reconfiguration of the routing switches. However this time slot could be reused for transmission of the destination bearings from one node to the next, on a link-by-link basis.
Figure 22 shows how the switch band would be divided into further sub-bands for use in -transmitting the destination bearing signals: two 100 ps-wide guard bands and an 800 ps-wide band which contains 2 bits of a 2.5 Gbit/s signal (representing the 2-bit 'destination bearings' word needed for dead reckoning in the MS-Net).
Figure 23 shows the arrangement for receiving these signals on an input link at a routing node. The additional components required are positioned after the delay unit shown in Figure 17. The 2.5 Gbit/s receiver could be BT&D type PDC 2201-2.4-FP. The decoder circuit would read in the signal bits, and output them as C
and D
bits to the routing logic processor (Figure 19). The optical modulator shown in Figure 23 performs the task of removing the 2.5 Gbit/s signals from the packet before reaching the access switch or address-field matching devices. The optical modulator must be capable of switching on or off in correct synchronism with the network clock in a time window of 100 ps, and provide 20 dB optical contrast ratio. A suitable device is the multiple-quantum well semiconductor electro-absorption modulator described by D. G. Moodie, A. D. Ellis, and C. W.
Ford (in "Generation of 6.3ps optical pulses at a lOGHz repetition rate using a packaged electro-absorption modulator and dispersion compensating fibre,"
Electron. Lett., vol. 30, no. 20, pp. 1 700-1 701 , 1 994).
Figure 24 shows the arrangement for inserting the 2.5 Gbit/s signals into the appropriate time band for a packet leaving a node. The components shown in Figure 24 would be inserted after the output buffer shown in Figure 17. The 2.5 Gbit/s optical transmitter could be of the DFB laser type with integral optical isolator, such as device QLM5S710 supplied by Lasertron Inc. The coder takes the appropriate destination bearing bits from the contention resolution processor, and provides an appropriate signal (the 2-bit 2.5 Gbit/s word described above) to the , transmitter with the correct time synchronisation to the network clock.
Tables TF19 and TF20 below are keys to the input and output data of the logic circuits of Figure 1 9 and 20 respectively.
References ( 1 ] D Cotter, M Shabeer, K Smith, J Lucek and D Rogers, "Ultrafast Self-Routing Networks", Proc. EFOC&N'95, vol. 2, pp. 210-213, Brighton, England (June 1995) [2] S Kawanishi, H Takara, O Kamatani and T Morioka, "100 Gbit/s, 500 km Optical Transmission Experiment", Opt. Soc. Am. Tech. Dig. OFC'95, vol. 8, pp.
287-288, San Diego iFebruary 1995) (3] J R Sauer, M N Islam and S P Dijaili, "A Soliton Ring Network", J.
Lightwave Technol., vol. 11, pp. 2182-2190 (1993) [4] D Cotter and S C Cotter, "Algorithm for Binary Word Recognition Suited to Ultrafast Nonlinear Optics", Elect. Lett., vol. 29, pp. 945-946 ( 1 993) [5] D Cotter, J K Lucek, M Shabeer, K Smith, D C Rogers, D Nesset and P
Gunning, "Self-Routing of 100 Gbit/s Packets Using 6-bit 'Keyword' Address 1 5 Recognition", Elect. Lett. (in press) [6] N F Maxemchuk, "Regular Mesh Topologies in Local and Metropolitan Area Networks", AT&T Tech. J., vol. 64, pp. 1659-1685 (1985) (7] N F Maxemchuk, "Routing in the Manhattan Street Network", IEEE Trans.
on Cornmun., vol. 35, pp. 503-512 (1987) (8] N F Maxemchuk, "Comparison of Deflection and Store-and-Forward Techniques in the Manhattan Street and Shuffle-Exchange Networks", Proc.
INFOCOM'89, pp. 800-809 (1989) (9) A K Choudhury and V O K Li, "Performance Analysis of Deflection Routing in the Manhattan Street Network", Proc. ICC'91 , pp. 1 659-1 664 (1 991 ) [10] D K Hunter and I Andonovic, "Optical Contention Resolution and Buffering Module for ATM Networks", Elect. Lett., vol. 29, pp. 280-281 ( 1 993) [11] P R Prucnal, "Optically-Processed Self-Routing, Synchronisation and Contention Resolution for 1 D and 2D Photonic Switch Architectures", IEEE J.
Quant. Electr., vol. 29, pp. 600-612 ( 1993) [12] C Partridge, Gigabit Networking, Addison Wesley, pp. 143-147 (1994) [13] S C Liew, "A General Packet Replication Scheme for Multicasting in Interconnection Networks", Proc. INFOCOM'95, pp. 394-400 (1995) [14] C Baransel, W Dobosiewicz and P Gburzynski, "Routing in Multihop Packet Switching Networks: Gigabit-per-second Challenge", IEEE Network, vol. 9, pp.
38-61 (May/June 1995) (15] A Bononi, F Forghieri and P R Prucnal, "Soliton Ultrafast All-Optical Mesh Networks", IEE Proc. J., vol. 140, pp. 285-290 (1993) [ 16] A G Nowatzyk and P R Prucnal, "Are Crossbars Really Dead? The Case for Optical Multiprocessor Interconnect Systems", ISCA'95 Intern. Conf. on Comp.
Architecture, Margherita Ligure, Italy (June 1995) [17] I Glesk, J P Sokoloff and P R Prucnal, "All-Optical Address Recognition and Self-Routing in a 250 Gbit/s Packet-Switched Network", Elect. Lett., vol.
30, pp. 1322-1323 (1994) (18] M Shabeer, J K Lucek, K Smith, D Cotter and D C Rogers, "Self-Synchronisation Scheme for High-Speed Photonic Networks", Elect. Lett.
(in press) 1 . Crosspoint oriented west-east and south-north i) Routing logic table for cell incoming from the west Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N don't careE, N

No E, S bar E, S E, S

W. N cross W, N W, N

No W, S don't careW, S

E, N cross E, N W, Nt Yes E, S bar W, St E, S

W. N cross W W
N N

, , W,S don't careW, S

E, N bar E, N E, St Yes No E, S bar E, S E, S

W. N cross W, St W, N

W, S don't careW,S

Yes any don't care (destination reached) ii) Routing logic table for a cell incoming from the south Input data_ Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N don't careE. N

No E, S cross E, S E, S

W, N bar W, N W, N

No W. S don't careW, S

E, N bar E, N W, Nt Yes E, S cross W, St E, S

W. N bar W, N W, N

W,S don't careW, S

E, N cross E, N E, St . Yes No E, S cross E, S E, S

W. N bar W. St W, N

W, S don't careW,S

Yes any don't car e (destination reached) +~..~ _ ~ _ ..............~ ......., uuyvm~ ucaumauum uCiiflrl9 °ITTer.
SUBSTITUTE SHEET (RULE 26) 2. Crosspoint oriented east-.west and south-.north i) Routing logic table for cell incoming from the east Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N cross E, N E, N

No E, S don't careE, S

W, N don't careW, N

No W, S bar W, S W, S

E, N cross E, N E, N

Yes E, S don't careE, S

W, N cross W, N E, Nt W, S bar E, St W, S

E, N cross E, St E, N

No E, S don't careE, S

Yes W, N bar W, N W, St W, S bar W, S W, S

Yes any don't care (destination reached) ii) Routing logic table for a cell incoming from the south Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N bar E, N E, N

No E, S don't careE, S

W, N don't careW, N

No W, S cross W, S W, S

E, N bar E, N E, N

Yes E, S don't careE, S

W, N bar W, N E, Nt W, S cross E, St W, S

E, N bar E, St E, N

No E, S don't careE, S

Yes W, N cross W, N W, St W, S cross W, S W, S

Yes any don't care (destination reached) tlncoming and outgoing destination bearing differ.
SUBSTITUTE SHEET (RULE 26) 3. Crosspoint oriented west-yeast and north~south i) Routing logic table for cell incoming from the west Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N bar E, N E, N

No E, S don't careE, S

W, N don't careW, N

No W, S cross W, S W, S

E, N bar W, Nt E, N
Yes E, S cross E, S W,St W, N don't careW, N

W, S cross W, S W, S

E, N bar E, N E, N
No E, S bar E, S E, Nt Yes W, N don't careW, N

W, S cross W, Nt W, S

Yes any don't care (destination reached) ii) Routing logic table for a cell incoming from the north Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N cross E, N E, N

No E, S don't careE, S

W, N don't careW, N

No W, S bar W, S W, S

E, N cross W, Nt E, N
Yes E, S bar E, S W,St W, N don't careW, N

W, S bar W, S W, S

E, N cross E, N E, N
No E, S cross E, S E, Nt Yes W, N don't careW, N

W, S bar W, Nt W, S

Yes any don't care (destination reached) tlncoming and outgoing destination bearing differ.
SUBSTITUTE SHEET (RULE 26) 4. Crosspoint oriented east-awest and north-.south i) Routing logic table for cell incoming from the east Input data Routing request Destination Crosspoint Destination Outgoing Incoming Outgoing row? column? switch destination destination destination bearings setting bearings bearings (requested (deflected routing) routing) E, N don't careE, N

No E, S cross E, S E, S

W, N bar W, N W, N

No W, S don't careW, S

E, N don't careE, N

Yes E, S cross E, S W, St W, N bar E, Nt W, N

W. S cross W, S W, S

E, N don't careE, N

Yes No E, S cross E, Nt E, S

W, N bar W, N W, N

W, S bar W, S W, Nt I ~ Yes ~ any ~ don't care (destination reached) ii) Routing logic table for cell incoming from the north Input data Routing request DestinationDestinationIncoming CrosspointOutgoing Outgoing row? column? destinationswitch destinationdestination bearings setting bearings bearings (requested(deflected routing) routing) E, N don't careE, N

No E, S bar E, S E, S

W, N cross W, N W, N

No W, S don't careW, S

E, N don't careE, N

Yes E, S bar E, S E, S

W, N cross E, Nt W, N

W, S bar W, S E, St E, N don't careE, N

Yes No E, S bar E, Nt E, S

W. N cross W, N W, N

W, S cross W, S W, Nt Yes any don't care (destination reached) tlncoming and outgoing destination bearing differ.
SUBSTITUTE SHEET (RULE 26) The efficiency of various routing schemes in MS-Nets of dimension mxn, relative to the shortest-path algorithm.
Average Maxemchuk's Random MS.Net shortestDead deterministic routing path reckoning routing (7) rules (7) mxn (no. Average 9596 RoutingRule Rules Rule Rule hops) distanceconfid. efficiencyrouting 2, 3 routing routing (no.hops)interval efficiencyroutingefficiencyefficiency efficiency 4x4 2.933332.93425 X0.0010 1.000 1.00 1.00 0.21 0.79 4x6 3.304353.56913 X0.0018 0.926 1.00 0.97 0.14 0.30 6x6 3.714294.11485 X0.0021 0.903 1.00 0.97 0.10 0.21 6x8 4.340434.83034 X0.0022 0.899 1.00 0.98 0.09 0.17 6x10 4.779665.45208 X0.0022 0.877 8x8 5.015875.53993 X0.0015 0.905 1.00 1.00 0.07 0.14 8x10 5.417726.11441 X0.0026 0.886 1.00 0.99 0.06 0.11 10x10 5.838386.64861 X0.0028 0.878 1.00 0.99 0.05 0.09 10x12 6.420177.28788 X0.0032 0.881 1.00 0.99 0.05 0.08 12x12 7.020987.91374 ,10.00300.887 1.00 1.00 0.04 0.07 12x14 7.449108.46980 X0.0046 0.879 1.00 1.00 0.04 0.06 14x14 7.887188.99996 X0.0043 0.876 1.00 0.99 0.03 0.06 16x16 9.0196110.196140.0030 0.885 18x18 9.9133011.3240 X0.0037 0.876 22x22 11.929613.5973 0.0038 0.877 24x24 13.015714.7628 ,10.00660.882 26x26 13.940715.8578 0.0061 0.879 32x32 17.012719.2481 X0.0085 0.884 48x48 25.009128.1283 X0.0088 0..889 50x50 25.969629.2233 X0.0107 0.889 62x62 31.975535.8524 X0.0138 0.892 64x64 33.007136.9633 X0.0116 0.893 SUBSTtTUTE SHEET (RULE 26) CIRCUIT DIAGRAM FOR ONTENTION-RESOLUTION LOGI~(' PROCESSOR
(Hot potato routing of two input packets, labelled A and B) , INPUT DATA
M, N: Routing request for packet A
M: Crosspoint switch setting: 0 = bar, 1 = cross N: Crosspoint switch setting care/don't care: O=care, 1 =don't care P, Q: Routing request for packet B
P: Crosspoint switching setting: O = bar, 1 = cross Q: Crosspoint switch setting care/don't care: O = care, 1 = don't care OUTPUT DATA (TO CROSSBAR ROUTING SWITCH) 1 5 R: Crosspoint switch setting: O = bar, 1 = cross SUBSTITUTE SHEET (RULE 26) GIRGIlIT DIAGRAI~~ FOR ROIITIV'~~r I OGIG PROCESSOR
(Crosspoint oriented west->east and south-north, cells incoming from the west) INPUT DATA
A: Node row = destination row? O=No, 1 =Yes B: Node column = destination column? O = No, 1 = Yes C: East-west destination bearing: O = east, 1 = west 10 D: North-south destination bearing: 0=north, 1 =south OUTPUT DATA (ROUTING REQUEST) E: Crosspoint switch setting: O = bar, 1 = cross F: Crosspoint switch setting care/don't care: 0=care, 1 =don't care 1 5 G, H: Output destination bearings (requested routing granted) G: O=east, 1 =west H: O = north, 1 = south J, K: Output destination bearings (requested routing not granted) J: O = east, 1 = west 20 K: O = north, 1 = south L: Node is destination? O = No, 1 = Yes SUBSTITUTE SHEET (RULE 26)

Claims (20)

1 . A method of routing a packet carried on a network having a generally regular topology comprising:
(a) receiving a packet at a node;
(b) reading a destination address and a directional flag, both of which are carried with the packet, the directional flag indicating explicitly a preferred direction of onward travel for the packet;
(c) making a local routing decision according to the value of the directional flag; and d) outputting the packet from the node in a direction selected in accordance with the routing decision.
2. A method according to claim 1, in which the packet is an optical packet carried on an optical network.
3. A method according to claim 2, including carrying out logical operations in the optical domain on information carried with the packet, and using the results of the logical operations in making a routing decision in step (c).
4. A method according to any one of the preceding claims, in which the network has at least two dimensions, and the packet carries at least two directional flags, one for each dimension of the network.
5. A method according to claim 4, further comprising comparing the destination address with the node address, and when the destination address is not the node address, but at least one field of destination address and node address correspond, then writing a new value for one or more of the directional flags carried by the packet.
6. A method according to any one of the preceding claims, in which the node, when it receives simultaneously two or more packets having the same preferred direction of onward trave, outputs one of the packets in a direction which is not the preferred direction.
7. A method according to any one of claims 1 to 6, in which the packet is first put onto the network at an originating node and the originating node determines from the destination address a direction of travel generally corresponding to the shortest route from the originating node to the destination address, and sets the or each directional flag accordingly.
8. A method according to any one of claims 1 to 7, in which the network has a toroidal topology.
9. A node for routing packets carried on a generally regular network, the node comprising:
a) an input for receiving a packet;
b) a routing decision unit for making a local routing decision using information carried by the packet, the routing decision unit including means responsive to a directional flag carried by the packet and indicating explicitly a preferred direction of onward travel;
c) a plurality of outputs for directing the packet onto the network. in different respective directions; and d) means for directing a packet to different respective ones of the plurality of outputs depending on an output of the routing decision unit.
10. A node according to claim 9 arranged to receive an optical packet at the input to the node.
11. A node according to claim 10 including one or more optical logic gates for carrying out a logical operation in the optical domain on information carried by the packet.
12. A node according to claim 11, in which the output of the or each logic gate is connected to the routing decision unit.
13. A node according to any one of claims 9 to 12, in which the node is arranged to be connected in a network having at least two dimensions and the routing decision unit is arranged to make a routing decision based on values of at least two directional flags, in use, the packet carrying one flag for each dimension of the network.
14. A network having a generally regular topology and including a plurality of nodes according to any one of claims 9 to 13.
15. A network according to claim 14, in which the network is an optical network.
16. A network according to claim 14 or 15, in which the network has a toroidal topology.
17. A network according to claim 16 having a Manhattan-Street-Network (MS Net) topology.
18. A computer system comprising a plurality of processors interconnected by a network according to any one of claims 14 to 17.
19. A local area network (LAN) comprising a network according to any one of claims 14 to 17.
20. A switch for use in a telecommunications network, including a network according to any one of claims 14 to 17.
CA002228219A 1995-07-28 1996-07-26 Packet routing Expired - Fee Related CA2228219C (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
GBGB9515536.2A GB9515536D0 (en) 1995-07-28 1995-07-28 Packet routing
GB9515536.2 1995-07-28
EP95306590 1995-09-19
EP95306590.1 1995-09-19
PCT/GB1996/001823 WO1997005725A1 (en) 1995-07-28 1996-07-26 Packet routing

Publications (2)

Publication Number Publication Date
CA2228219A1 CA2228219A1 (en) 1997-02-13
CA2228219C true CA2228219C (en) 2002-10-15

Family

ID=26140349

Family Applications (1)

Application Number Title Priority Date Filing Date
CA002228219A Expired - Fee Related CA2228219C (en) 1995-07-28 1996-07-26 Packet routing

Country Status (12)

Country Link
US (1) US6272548B1 (en)
EP (1) EP0872087B1 (en)
JP (1) JPH11510335A (en)
KR (1) KR19990036054A (en)
CN (1) CN1094008C (en)
AU (1) AU712810B2 (en)
CA (1) CA2228219C (en)
DE (1) DE69624591T2 (en)
MX (1) MX9800791A (en)
NO (1) NO980366L (en)
NZ (1) NZ313707A (en)
WO (1) WO1997005725A1 (en)

Families Citing this family (68)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6163392A (en) * 1997-05-23 2000-12-19 Ciena Corporation Distributed intelligence wavelength division multiplexed network
US7039312B1 (en) 1997-05-23 2006-05-02 Ciena Corp Distributed intelligence wavelength division multiplexed network
US6285679B1 (en) 1997-08-22 2001-09-04 Avici Systems, Inc. Methods and apparatus for event-driven routing
EP1016244B1 (en) * 1997-09-17 2007-04-18 BRITISH TELECOMMUNICATIONS public limited company Communications network
US6618368B1 (en) * 1998-02-19 2003-09-09 Hitachi, Ltd. Data gateway and method for relaying data
US6359879B1 (en) 1998-04-24 2002-03-19 Avici Systems Composite trunking
CN1183720C (en) * 1999-05-11 2005-01-05 英国电讯有限公司 Optical communications network
US7310688B1 (en) 1999-08-30 2007-12-18 Ciena Corporation Relative addressing for network elements
US6693877B1 (en) * 1999-09-07 2004-02-17 Motorola, Inc. Data discard avoidance method
GB2354912B (en) * 1999-09-17 2004-03-10 Ericsson Telefon Ab L M Routing in a packet switched network
US6694098B1 (en) * 1999-12-13 2004-02-17 Nortel Networks Limited Apparatus and method for reading data from an optical packet header
DE10023309A1 (en) * 2000-05-15 2001-11-22 Bosch Gmbh Robert Data packet communication method in Internet, involves including allocation information in data packet, for allocating portion of location information to respective description information
US6714966B1 (en) * 2000-07-31 2004-03-30 The Boeing Company Information delivery service
US6732147B1 (en) 2000-07-31 2004-05-04 The Boeing Company Leaving a broadcast channel
US6920497B1 (en) 2000-07-31 2005-07-19 The Boeing Company Contacting a broadcast channel
US6910069B1 (en) 2000-07-31 2005-06-21 The Boeing Company Joining a broadcast channel
US6701344B1 (en) * 2000-07-31 2004-03-02 The Boeing Company Distributed game environment
AU2001296628A1 (en) 2000-09-27 2002-04-08 Hrl Laboratories, Llc Method and apparatus for providing directed communications through a networked array of nodes
KR100657120B1 (en) * 2000-11-04 2006-12-12 주식회사 케이티 A Method for Routing for Balancing Load in Packet-Switched network
EP1211842A1 (en) * 2000-11-30 2002-06-05 BRITISH TELECOMMUNICATIONS public limited company Network management apparatus
JP2002190825A (en) * 2000-12-21 2002-07-05 Fujitsu Ltd Traffic engineering method and node equipment using it
US7080156B2 (en) * 2002-03-21 2006-07-18 Sun Microsystems, Inc. Message routing in a torus interconnect
US7457416B1 (en) 2002-07-17 2008-11-25 Bbn Technologies Corp. Key distribution center for quantum cryptographic key distribution networks
US7627126B1 (en) 2002-10-15 2009-12-01 Bbn Technologies Corp. Systems and methods for implementing path length control for quantum cryptographic systems
US7512242B2 (en) * 2003-03-21 2009-03-31 Bbn Technologies Corp. Systems and methods for quantum cryptographic key transport
US7430295B1 (en) 2003-03-21 2008-09-30 Bbn Technologies Corp. Simple untrusted network for quantum cryptography
US7706535B1 (en) * 2003-03-21 2010-04-27 Bbn Technologies Corp. Systems and methods for implementing routing protocols and algorithms for quantum cryptographic key transport
CN100455035C (en) * 2003-09-02 2009-01-21 华为技术有限公司 Routing method of forward constraint backward selecting
US7515716B1 (en) 2004-02-26 2009-04-07 Bbn Technologies Corp. Systems and methods for reserving cryptographic key material
US20060080461A1 (en) * 2004-06-02 2006-04-13 Wilcox Jeffrey R Packet exchange for controlling system power modes
US7603404B2 (en) * 2004-12-20 2009-10-13 Sap Ag Grid parallel execution
US7720970B2 (en) * 2005-09-30 2010-05-18 Microsoft Corporation Method for processing received networking traffic while playing audio/video or other media
JP4158803B2 (en) * 2005-12-13 2008-10-01 沖電気工業株式会社 Data transfer network and operation method of data transfer network
US20070233835A1 (en) * 2006-03-31 2007-10-04 Nandakishore Kushalnagar Methodology for scheduling data transfers from nodes using path information
US7962717B2 (en) * 2007-03-14 2011-06-14 Xmos Limited Message routing scheme
US8161480B2 (en) 2007-05-29 2012-04-17 International Business Machines Corporation Performing an allreduce operation using shared memory
US8140826B2 (en) * 2007-05-29 2012-03-20 International Business Machines Corporation Executing a gather operation on a parallel computer
US20090006663A1 (en) * 2007-06-27 2009-01-01 Archer Charles J Direct Memory Access ('DMA') Engine Assisted Local Reduction
US7827385B2 (en) * 2007-08-02 2010-11-02 International Business Machines Corporation Effecting a broadcast with an allreduce operation on a parallel computer
US7734706B2 (en) * 2007-08-22 2010-06-08 International Business Machines Corporation Line-plane broadcasting in a data communications network of a parallel computer
US7840779B2 (en) * 2007-08-22 2010-11-23 International Business Machines Corporation Line-plane broadcasting in a data communications network of a parallel computer
US7991857B2 (en) * 2008-03-24 2011-08-02 International Business Machines Corporation Broadcasting a message in a parallel computer
US8122228B2 (en) * 2008-03-24 2012-02-21 International Business Machines Corporation Broadcasting collective operation contributions throughout a parallel computer
US8422402B2 (en) 2008-04-01 2013-04-16 International Business Machines Corporation Broadcasting a message in a parallel computer
US8161268B2 (en) * 2008-05-21 2012-04-17 International Business Machines Corporation Performing an allreduce operation on a plurality of compute nodes of a parallel computer
US8375197B2 (en) * 2008-05-21 2013-02-12 International Business Machines Corporation Performing an allreduce operation on a plurality of compute nodes of a parallel computer
US8484440B2 (en) 2008-05-21 2013-07-09 International Business Machines Corporation Performing an allreduce operation on a plurality of compute nodes of a parallel computer
US8281053B2 (en) 2008-07-21 2012-10-02 International Business Machines Corporation Performing an all-to-all data exchange on a plurality of data buffers by performing swap operations
US8285900B2 (en) 2009-02-17 2012-10-09 The Board Of Regents Of The University Of Texas System Method and apparatus for congestion-aware routing in a computer interconnection network
US8565089B2 (en) * 2010-03-29 2013-10-22 International Business Machines Corporation Performing a scatterv operation on a hierarchical tree network optimized for collective operations
US8332460B2 (en) 2010-04-14 2012-12-11 International Business Machines Corporation Performing a local reduction operation on a parallel computer
US9424087B2 (en) 2010-04-29 2016-08-23 International Business Machines Corporation Optimizing collective operations
US8346883B2 (en) 2010-05-19 2013-01-01 International Business Machines Corporation Effecting hardware acceleration of broadcast operations in a parallel computer
US8489718B1 (en) * 2010-05-19 2013-07-16 Amazon Technologies, Inc. Torroidal backbone connections for network deployment
US8949577B2 (en) 2010-05-28 2015-02-03 International Business Machines Corporation Performing a deterministic reduction operation in a parallel computer
US8489859B2 (en) 2010-05-28 2013-07-16 International Business Machines Corporation Performing a deterministic reduction operation in a compute node organized into a branched tree topology
US8776081B2 (en) 2010-09-14 2014-07-08 International Business Machines Corporation Send-side matching of data communications messages
US8566841B2 (en) 2010-11-10 2013-10-22 International Business Machines Corporation Processing communications events in parallel active messaging interface by awakening thread from wait state
US8893083B2 (en) 2011-08-09 2014-11-18 International Business Machines Coporation Collective operation protocol selection in a parallel computer
US8667501B2 (en) 2011-08-10 2014-03-04 International Business Machines Corporation Performing a local barrier operation
US8910178B2 (en) 2011-08-10 2014-12-09 International Business Machines Corporation Performing a global barrier operation in a parallel computer
FR2980939A1 (en) * 2011-09-30 2013-04-05 France Telecom MULTI-SKIP ROUTING PROTOCOL
US9495135B2 (en) 2012-02-09 2016-11-15 International Business Machines Corporation Developing collective operations for a parallel computer
EP2665212B1 (en) * 2012-05-16 2016-11-30 Alcatel Lucent Optical data transmission system
US9774401B1 (en) * 2013-07-15 2017-09-26 Paul Borrill Entangled links, transactions and trees for distributed computing systems
US10116557B2 (en) 2015-05-22 2018-10-30 Gray Research LLC Directional two-dimensional router and interconnection network for field programmable gate arrays, and other circuits and applications of the router and network
US10069716B2 (en) 2015-07-29 2018-09-04 At&T Intellectual Property I, L.P. Methods and apparatus to reflect routes from a remotely located virtual route reflector
CN107749819B (en) * 2017-09-14 2020-07-21 北京东土科技股份有限公司 Routing method and device under grid network condition

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4805091A (en) * 1985-06-04 1989-02-14 Thinking Machines Corporation Method and apparatus for interconnecting processors in a hyper-dimensional array
EP0221360B1 (en) * 1985-11-04 1992-12-30 International Business Machines Corporation Digital data message transmission networks and the establishing of communication paths therein
US4811210A (en) * 1985-11-27 1989-03-07 Texas Instruments Incorporated A plurality of optical crossbar switches and exchange switches for parallel processor computer
US4731878A (en) * 1985-11-29 1988-03-15 American Telephone And Telegraph Company, At&T Bell Laboratories Self-routing switch node combining electronic and photonic switching
US4933933A (en) * 1986-12-19 1990-06-12 The California Institute Of Technology Torus routing chip
US5105424A (en) * 1988-06-02 1992-04-14 California Institute Of Technology Inter-computer message routing system with each computer having separate routinng automata for each dimension of the network
DE69127423T2 (en) * 1990-11-14 1998-02-19 Nec Corp Self-routing network with optical gate matrix
US5327552A (en) * 1992-06-22 1994-07-05 Bell Communications Research, Inc. Method and system for correcting routing errors due to packet deflections
SE518622C2 (en) * 1992-07-03 2002-10-29 Ericsson Telefon Ab L M Method and apparatus for monitoring branched optical wiring networks
US5617413A (en) * 1993-08-18 1997-04-01 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Scalable wrap-around shuffle exchange network with deflection routing
EP0642244B1 (en) * 1993-08-24 2003-07-23 Canon Kabushiki Kaisha Network for connecting a plurality of nodes using a plurality of channels
US5488608A (en) * 1994-04-14 1996-01-30 Metricom, Inc. Method and system for routing packets in a packet communication network using locally constructed routing tables
DE69515171T2 (en) * 1994-05-23 2000-09-14 British Telecomm OPTICAL TELECOMMUNICATIONS NETWORK
US5606551A (en) * 1994-12-21 1997-02-25 Lucent Technologies Inc. Bidirectional mesh network
US5602838A (en) * 1994-12-21 1997-02-11 Lucent Technologies Inc. Global multi-satellite network
US5875185A (en) * 1995-10-10 1999-02-23 Industrial Technology Research Inst. Seamless handoff for a wireless lan/wired lan internetworking
US5917820A (en) * 1996-06-10 1999-06-29 Cisco Technology, Inc. Efficient packet forwarding arrangement for routing packets in an internetwork

Also Published As

Publication number Publication date
CN1094008C (en) 2002-11-06
US6272548B1 (en) 2001-08-07
AU6623496A (en) 1997-02-26
DE69624591T2 (en) 2003-06-26
NO980366L (en) 1998-03-20
CN1192307A (en) 1998-09-02
CA2228219A1 (en) 1997-02-13
DE69624591D1 (en) 2002-12-05
EP0872087A1 (en) 1998-10-21
KR19990036054A (en) 1999-05-25
JPH11510335A (en) 1999-09-07
NZ313707A (en) 1999-04-29
AU712810B2 (en) 1999-11-18
MX9800791A (en) 1998-04-30
NO980366D0 (en) 1998-01-27
EP0872087B1 (en) 2002-10-30
WO1997005725A1 (en) 1997-02-13

Similar Documents

Publication Publication Date Title
CA2228219C (en) Packet routing
US5912753A (en) Optical telecommunications network
CA2302260C (en) Method of packet transmission in communications network
Varvarigos The" packing" and the" scheduling packet" switch architectures for almost all-optical lossless networks
Yuan et al. A Novel Self-Routing Address Scheme for All-Optical Packet-Switched NetworksWith Arbitrary Topologies
EP0389097B1 (en) Photonic local/metropolitan area network
Yang et al. Traffic control and WDM routing in the data vortex packet switch
US5218198A (en) Optical waveguide switch utilizing means for detecting a tapped off fraction of the input signal
US7433597B2 (en) Deflection routing address method for all-optical packet-switched networks with arbitrary topologies
Kannan et al. SXmin: A self-routing high-performance ATM packet switch based on group-knockout principle
Yu et al. Analysis of a dual-receiver node with high fault tolerance for ultrafast OTDM packet-switched shuffle networks
Cotter et al. Ultrafast all-optical signal processing for packet switching
Cotter et al. ‘Dead reckoning’—a primitive and efficient self-routing protocol for ultrafast mesh networks
Bononi et al. New structures of the optical node in multihop transparent optical networks with deflection routing
Gjessing A novel method for re-routing in obs networks
JP2557873B2 (en) Self-routing speech path
Stampoulidis et al. ARTEMIS: a 40 Gb/s all-optical self-router using asynchronous bit and packet-level optical signal processing
Bononi et al. Novel structures of the optical node in multihop transparent optical networks using deflection routing
Fayoumi et al. Performance evaluation of an all-optical ShuffleNet using optical buffering and deflection routing
Prucnal et al. Optical self-routing in a self-clocked photonic switch using pulse-interval encoding
Prakash et al. ATM switch: As an Application of VLSI in Telecommunication System
Fayoumi et al. Comparison of optical buffering and store-and-forward mechanisms in optical networks
Reljin et al. Application of Neural Networks in Solving Some Problems in Modern Telecommunications
Li et al. Improving the performance of optical burst switching with large control overhead
Yu Optical time-division multiplexing packet-switched local area networks: Design and demonstrations

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed