US20080043621A1 - Systems and Methods for Improving Network Performance - Google Patents
Systems and Methods for Improving Network Performance Download PDFInfo
- Publication number
- US20080043621A1 US20080043621A1 US11/923,732 US92373207A US2008043621A1 US 20080043621 A1 US20080043621 A1 US 20080043621A1 US 92373207 A US92373207 A US 92373207A US 2008043621 A1 US2008043621 A1 US 2008043621A1
- Authority
- US
- United States
- Prior art keywords
- packet
- network
- transmission
- tcp
- congestion
- 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.)
- Abandoned
Links
- 238000000034 method Methods 0.000 title claims abstract description 57
- 230000005540 biological transmission Effects 0.000 claims abstract description 60
- 238000004891 communication Methods 0.000 claims abstract description 41
- 230000004044 response Effects 0.000 claims abstract description 13
- 230000001934 delay Effects 0.000 claims abstract description 5
- 238000005259 measurement Methods 0.000 claims description 17
- 238000001514 detection method Methods 0.000 claims description 13
- 238000013178 mathematical model Methods 0.000 claims 4
- 230000006978 adaptation Effects 0.000 claims 2
- 238000012545 processing Methods 0.000 description 10
- 238000013461 design Methods 0.000 description 4
- 101150102482 BBLN gene Proteins 0.000 description 3
- 238000012888 cubic function Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 238000013213 extrapolation Methods 0.000 description 2
- ORQBXQOJMQIAOY-UHFFFAOYSA-N nobelium Chemical compound [No] ORQBXQOJMQIAOY-UHFFFAOYSA-N 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 239000002253 acid Substances 0.000 description 1
- 239000000872 buffer Substances 0.000 description 1
- 230000015556 catabolic process Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 238000006731 degradation reaction Methods 0.000 description 1
- 238000000691 measurement method Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/11—Identifying congestion
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/12—Avoiding congestion; Recovering from congestion
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/19—Flow control; Congestion control at layers above the network layer
- H04L47/193—Flow control; Congestion control at layers above the network layer at the transport layer, e.g. TCP related
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/25—Flow control; Congestion control with rate being modified by the source upon detecting a change of network conditions
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/28—Flow control; Congestion control in relation to timing considerations
- H04L47/283—Flow control; Congestion control in relation to timing considerations in response to processing delays, e.g. caused by jitter or round trip time [RTT]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/37—Slow start
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/163—In-band adaptation of TCP data exchange; In-band control procedures
Definitions
- the present application relates to computer/communication networking and in particular relates to improved methods for detecting and avoiding network congestion and for reducing retransmission latencies in packetized protocols applied to network communications.
- the nodes may be, for example, computing devices, storage devices for storing information, or other communication or network appliances for generating, receiving, storing, forwarding or routing the packets of information.
- the communication medium may be widely distributed as in a so-called wide area network (“WAN”) or localized within an enterprise as in a so-called local are network (“LAN”).
- WAN wide area network
- LAN local are network
- the information be exchanged between nodes is generally subdivided into one or more packets. Each packet may include some subset of the total information to be exchanged between nodes over the network. Packets may be fixed or variable in size in accordance with the particular protocols and communication media employed. Further, each packet may represent a unit of information to be verified and acknowledged between the nodes in accordance with the particular protocols and media employed.
- information is subdivided into one or more packets of variable sizes less than a pre-determined maximum size.
- Packets are initially transmitted in a sequential order corresponding to the order of the information to be exchanged.
- Individual packets are each identified by a sequence ID field to indicate their proper order relative to one another.
- the receiving node(s) may then reassemble the received packets into the originally transmitted information.
- Ethernet and other communication media allow devices to communicate over multiple segments of communication links through one or more intermediate nodes or devices. Where the multiple links vary in speed or where the intermediate device(s) are of variable processing capability, a sequence of packets transmitted from a sender to a receiver may cause congestions. Packets moving from a faster network segment or node to a slower segment may over-run the available bandwidth of the slower link or node. If the intermediate node detects such congestion it may discard received packets from its internal queues.
- Such congestion may be more common where multiple transmitters attempt to forward packets through a common segment or node.
- a single node may generate and transmit packets so quickly that it may, alone, utilize all available bandwidth.
- Such saturation of the communication medium can cause packet loss if the receiving intermediate node(s) or segment(s) cannot process the received packets quickly enough.
- TCP/IP and other common protocols may cause retransmission of packets that were lost and all subsequent packets from that point forward (in the sequence of transmitted packets). Such retransmissions are costly in terms of elapsed time to complete the desired transmission and in terms of bandwidth utilization since information (packets) previously transmitted must be transmitted again.
- the sender determines that a packet has been missed by the receiving node when the sending node receive three consecutive acknowledgement messages (i.e., TCP/IP ACK messages) each indicating a duplicate sequence ID value.
- present TCP/IP (and other) protocols use techniques to attempt to estimate the available bandwidth on the communication medium and then to use the estimated available bandwidth to limit the transmitting node in hopes of thereby avoiding congestion and the resulting packet loss and performance degradation.
- Presently known techniques such as those practiced in the present-day Reno version of the TCP/IP protocols (“Reno TCP/IP”), attempt to avoid congestion by predicting the available bandwidth of the communication medium and then limiting the transmitting node to a fixed percentage thereof RFC2581 provides specifications for the TCP/IP protocol for presently known techniques to reduce congestion packet loss and the associated packet retransmission.
- RFC2581 and other related TCP/IP specifications are readily available to those of ordinary skill in the art and may be found, for example, at http://www.rfc-editor.org/rfc.html.
- these presently practiced techniques predict the available bandwidth using essentially static information regarding the communication medium at a fixed point in time.
- present techniques such as those in Reno TCP/IP, often intentionally generate packet loss conditions in order to determine the available bandwidth on the communication medium.
- the present invention solves the above and other problems, thereby advancing the state of the useful arts, by providing improved methods and structures for detecting and avoiding network congestion and for detecting and retransmitting lost packets when required.
- the available bandwidth is estimated dynamically by features hereof that continually learn the available bandwidth of the network medium based on mathematical analysis of one or more past responses from the receiving node(s).
- Another aspect hereof uses a curve fitting mathematical analysis of prior responses from the receiving node to permit interpolation/extrapolation techniques to predict an estimated future response.
- Still other aspects hereof improve the speed of detecting loss of a packet by improving the accuracy of round-trip time (“RTT”) estimates.
- the RTT is estimated based on measurements of the actual time to respond from previous acknowledged packet transmissions.
- a feature hereof therefore provides a method of reducing network congestion comprising the steps of: transmitting multiple packets from a sending node to a receiving node over a network communication medium at a rate no faster than a predetermined maximum packet transmission rate value; receiving multiple acknowledgements at the sending node from the receiving node; measuring a transmission performance value based on transmission of a packet of the multiple packets and a corresponding acknowledgement of the multiple acknowledgements; predicting an available bandwidth value based on at least two transmission performance values; and adjusting the predetermined maximum packet transmission rate based on the predicted available bandwidth to reduce network congestion on the network communication medium.
- Another feature hereof provides a method for reducing re-transmission delays in a packetized network protocol comprising: measuring a time between a successful packet transmission and receipt of a corresponding acknowledgement; using the measured time as a timeout value for a subsequent packet transmission; detecting expiration of the timeout value following the transmission of the subsequent packet; and retransmitting the subsequent packet in response to detecting expiration of the timeout value.
- Another feature hereof provides a system comprising: a packet network communication medium; a first network appliance communicatively coupled to the medium; and one or more other network appliances communicatively coupled to the first networl appliance via the medium, such that the first network appliance further comprises: a predictive tuning element to dynamically predictively adapt protocol parameters of the first network appliance based on present and past measurements of throughput on the medium.
- FIG. 1 is a block diagram of an exemplary network appliance enhanced in accordance with features and aspects hereof.
- FIG. 2 is a flowchart describing an exemplary method for tuning retransmission parameters in accordance with features and aspects hereof.
- FIG. 3 is a flowchart describing an exemplary method for applying dynamically tuned retransmission parameters in accordance with features and aspects hereof.
- FIG. 4 is a flowchart describing an exemplary method for operating a TCP transmitter in accordance with features and aspects hereof.
- FIG. 5 is a flowchart describing an exemplary method for dynamically adjusting TCP/IP parameters used by the exemplary transmitter of FIG. 5 to reduce network congestion.
- FIG. 1 is a block diagram depicting an enhanced network appliance 100 coupled to two other network appliances 120 and 130 via, packet network communication medium 150 .
- Packet network communication medium 150 may be any appropriate packet switched network communication medium and protocol appropriate for the particular application.
- medium 150 maybe a TCP/IP network protocol applied to an Ethernet communication medium.
- Network appliance 100 maybe any node or computing device adapted for coupling to such a packet network communication medium 150 .
- network appliance 100 may be a personal computer or workstation or any network appliance including bridges, routers, hubs, etc.
- Network appliance 100 includes packet transmitter element 106 and packet receiver element 108 for transmitting and receiving packets, respectively, via media 150 .
- Packet processing element 110 generates packets to be transmitted via packet transmitter 106 and reconstructs buffers of data from received packets received via packet receiver element 108 .
- network appliance 100 may also include dynamic congestion avoidance element 102 and dynamic retransmission tuning element 104 to improve network communications capabilities of network appliance 100 (collectively or individually also referred to herein as a predictive tuning element 101 ).
- Dynamic retransmission tuning element 104 is generally operable to adjust parameters of the packet transmission protocol to reduce latencies associated with retransmission of a failed or lost packet.
- Dynamic congestion avoidance element 102 also tunes parameters of the packet protocol to reduce the possibility of congestion generated by network appliance 100 on the communication medium 150 . By reducing the possibility of such congestion on the communication medium 150 , enhanced network appliance 100 improves overall system performance by reducing the number of occurrences of lost packets and associated, time consuming, packet retransmissions.
- by dynamically tuning the retransmission related protocol parameters latencies associated with the occasional need for retransmission may be reduced thereby further improving overall system performance.
- FIG. 2 is a flowchart describing an exemplary method associated with features and aspects hereof operable to dynamically tune protocol parameters to reduce the latencies associated with packet retransmission.
- the exemplary method is adapted to measure the time between transmission of a packet and receipt of a corresponding acknowledgement message (“ACK”) for the transmitted packet.
- the round trip time TCP/IP parameter (“RTT”) is then set to the measured elapsed time between packet transmission and receipt of a corresponding acknowledgement.
- element 200 is operable to start a timer following detection of a packet transmission by transmitting elements of the associated network appliance.
- Element 202 then loops, awaiting detection of the ACK message corresponding to the transmitted packet.
- element 203 Upon receipt of the corresponding ACK message, element 203 is operable to estimate the next RTT value based on the elapsed time between the packet transmission and the corresponding ACK receipt.
- the next RTT value may be predicted as a function of the current throughput value (computed from the measured time interval) and previous measured values. As discussed further herein below, a cubic spline function may be used such that the next RTT value may be extrapolated from the current RTT estimated value and one or more past measured values.
- element 204 next sets RTT to the predicted next value.
- the method of FIG. 2 thus may dynamically adjust the RTT TCP/IP parameter value according to measured and extrapolated throughput values.
- the method of FIG. 2 may be operable to dynamically adjust RTT in response to every packet transmission (and receipt of a corresponding ACK). Alternatively, the method that may be operable periodically in response to transmission of selected packets (and receipt of corresponding ACKs).
- FIG. 3 is a flowchart describing exemplary enhanced operation of a network appliance to utilize the dynamically tuned retransmission parameters to reduce the latencies associated with lost packet retransmission.
- Element 300 is first operable to initiate transmission of a packet.
- Element 302 then starts a timer with the RTT timeout value most recently determined.
- Element 304 determines whether any ACK message has been received.
- element 306 is operable to determine whether the ACK message acknowledges the packet transmitted at element 300 . If so, transmission of the packet is successful and the method completes normally. If the received ACK does not acknowledge the transmitted packet, element 308 is next operable to determine whether the RTT timeout period has expired.
- element 310 determines whether the received acknowledgement message is a duplicate acknowledgement message (i.e., duplicating a preceding received acknowledgement message).
- acknowledgement message is not a duplicate ACK
- processing continues looping back to the element 304 to await receipt of another acknowledgement message. If element 310 determines that the received ACK is a duplicate ACK, indicating likely loss of a transmitted packet, element 312 is then operable to commence retransmission processing.
- features and aspects hereof reduce the delay in determining that a retransmission must occur.
- prior techniques as documented in, for example, RFC2581
- features and aspects hereof my detect the need to transmit by waiting for two duplicate ACK messages and the expiration of the RTT timeout period. Since the RTT timeout period is dynamically adjusted by features and aspects hereof, the timeout may be tuned to an optimal or near optimal value.
- features and aspects hereof may notably reduce the time required to detect the need for a retransmission of a previously sent packet.
- FIG. 4 is a flowchart describing operation of a transmitter element of a network appliance enhanced with features and aspects hereof to reduce network congestion.
- Element 400 is operable to initialize transmission related parameters of the packet protocol. For example, as applied to TCP/IP protocol exchanges, “ssthresh” (slow start threshold) and “cwnd” (congestion window) are initialized according to the standards of the “slow start” mode of TCP/IP protocol specifications (such as in RFC2581). Element 402 then commences transmission operation using the slow start TCP IP mode until an appropriate equilibrium state is achieved (i.e., when cwnd first exceeds ssthresh in accordance with RFC2581).
- slow start threshold slow start threshold
- cwnd congestion window
- element 404 When slow start transmission mode finely achieves an appropriate equilibrium, element 404 is operable to commence normal transmit operation in accordance with enhanced congestion avoidance features and aspects hereof.
- previously known techniques achieve an equilibrium status and then, when a packet loss is detected and a corresponding retransmission initiated, reverts again to slow start mode.
- features and aspects hereof enhance congestion avoidance techniques by dynamically measuring actual throughput performance on the network medium and predicting future performance therefrom. The predicted future performance may then be used to periodically and dynamically adjust the cwnd congestion avoidance TCP/IP parameter to reduce the possibility of congestion on the network medium.
- elements 406 and 408 are operable to detect bandwidth changes from performance measurements made during normal packet transmission to the network medium and to dynamically adjust cwnd in accordance with those measured parameters. Element 410 then determines whether congestion has been detected on the network as reflected by a lost packet and the need for a corresponding packet retransmission. If no such congestion and corresponding retransmission is detected, processing continues in the enhanced congestion avoidance mode of operation. Elements 406 and 408 continue to dynamically measure network performance and adjust congestion detection related parameters of the TCP/IP transmitter.
- processing continues by looping back to element 402 to reinitialize the TCP/IP transmitter of the enhanced appliance and to restart transmission using the “slow stall” mode of operation specified by TCP/IP protocol standards.
- the method of FIG. 4 will rarely encounter congestion by operation of element 410 .
- the method of FIG. 4 improves congestion avoidance such that congestion occurs less frequently and hence is rarely detected.
- the iterative operation of elements 406 , 408 and 410 therefore predominate the operation of the node transmitter as regards adjustment to and monitoring of throughput and associated congestion avoidance.
- prior techniques adapted to changes in throughput very slowly or not at all. Cwnd parameter values would change very slowly or even remain static in accordance with prior techniques. In general, prior techniques simply started over with the slow start techniques when congestion was detected (by packet loss).
- FIG. 5 is a flow chart describing an exemplary performance measurement method in accordance with features and aspects hereof.
- performance is measured by counting events or timing events relating to aspects of the communication medium operation between transmission of a packet and receipt of a corresponding acknowledgement message for the transmitted packet.
- a packet pair algorithm may be applied to this measurement.
- the packet pair algorithm relies on the presumption that if two packets to be transmitted are queued next to one another in a queue at a link/node representing the performance bottleneck in communications, the two packets will exit that link in a predictable manner.
- the time between the two packet transmissions is computable in accordance with the measured performance of the bottleneck link and the known packet size.
- S is the packet size and t 1 and t 2 are the absolute times of arrival of two acknowledgement messages: t 1 corresponding to the arrival of the ACK for the first packet and t 2 corresponding to the arrival of the ACK for the second packet.
- bandwidth may be measured by counting the number of packets of equal size transmitted before receiving an acknowledgement for a first of a sequence of such packets.
- the future performance of the communication medium may be extrapolated from this current performance measurement and past measurements.
- the next cwnd parameter value may then be computed as the previous value plus or minus any incremental value.
- the incremental value may be determined as the minimum of a value computed from the predicted next throughput value and a value determined by exponential or linear increases dictated by the slow start standard congestion avoidance techniques.
- the congestion window (cwnd TCP/IP parameter value) is adjusted by the lesser of the next predicted throughput value and the linear increase value as normally utilized in slow start processing. If the current throughput is far from ssthresh, then cwnd is adjusted by the lesser of the next predicted throughput value and the exponential increase value as normally utilized in congestion avoidance processing.
- the RTT TCP/IP parameter could be similarly adapted based on current and previous throughput measurements and extrapolated values.
- element, 500 is operable to await detection of a packet transmission by the packet transmitter element described above.
- element 502 is next operable to start an appropriate timer or counter to measure the desired performance parameter.
- performance may be measured in accordance with the time between receipt of consecutive acknowledgement messages or as a function of the number of packets transmitted between the transmission of a first packet and receipt of the acknowledgement corresponding to that first packet.
- the timer or counter then continues while element 504 awaits detection of an appropriate acknowledgement message.
- element 506 determines the final time or count value as measured from the start of the measurement at element 502 until detection of the relevant acknowledgement message at element 504 .
- Element 508 determines an appropriate performance measurement from the final time work and value measured by element 506 .
- Element 510 is operable to predict the next performance measure from the current and previous performance measurement values.
- a cubic spline function may be applied to predict a next performance value from current and previous performance and values as follows:
- the cubic spline extrapolation is based on fitting a cubic function curve through all the points of a given set.
- A ( Xi+ 1 ⁇ X )/( Xi+ 1 ⁇ Xi )
- B ( X ⁇ Xi )/( Xi+ 1 ⁇ Xi )
- C 1 ⁇ 6( A 3 ⁇ A )( Xi+ 1 ⁇ Xi ) 2
- D 1 ⁇ 6( B 3 ⁇ B )( Xi+ 1 ⁇ Xi ) 2
- Element 512 is then operable to adjust the TCP/IP transmitter's cwnd parameter based on the predicted next performance measurement. Processing then continues looping back to element 500 to await a next packet transmission.
- the method of FIG. 5 may be operable to dynamically adjust cwnd in response to every packet transmission. Alternatively, the method that may be operable periodically in response to transmission of selected packets.
- the sending node may reduce potential for congestion on the network medium and thereby improve overall system performance by reducing potential for packet loss and associated retransmission.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
Description
- 1. Field of the Invention
- The present application relates to computer/communication networking and in particular relates to improved methods for detecting and avoiding network congestion and for reducing retransmission latencies in packetized protocols applied to network communications.
- 2. Discussion of Related Art
- Many present day communication networks exchange packets of information between nodes coupled to a common communication medium. The nodes may be, for example, computing devices, storage devices for storing information, or other communication or network appliances for generating, receiving, storing, forwarding or routing the packets of information. The communication medium may be widely distributed as in a so-called wide area network (“WAN”) or localized within an enterprise as in a so-called local are network (“LAN”). The information be exchanged between nodes is generally subdivided into one or more packets. Each packet may include some subset of the total information to be exchanged between nodes over the network. Packets may be fixed or variable in size in accordance with the particular protocols and communication media employed. Further, each packet may represent a unit of information to be verified and acknowledged between the nodes in accordance with the particular protocols and media employed.
- For example, in TCP/IP protocols applied to Ethernet communication media, information is subdivided into one or more packets of variable sizes less than a pre-determined maximum size. Packets are initially transmitted in a sequential order corresponding to the order of the information to be exchanged. Individual packets are each identified by a sequence ID field to indicate their proper order relative to one another. The receiving node(s) may then reassemble the received packets into the originally transmitted information.
- In TCP/IP networks and other packetized networks, packets may be lost in transmission for various reasons. For example, a noisy communication medium (one having a low signal to noise ratio) may cause errors in the transmitted packets. Another reason for packet loss is congestion on the communication medium. Ethernet and other communication media allow devices to communicate over multiple segments of communication links through one or more intermediate nodes or devices. Where the multiple links vary in speed or where the intermediate device(s) are of variable processing capability, a sequence of packets transmitted from a sender to a receiver may cause congestions. Packets moving from a faster network segment or node to a slower segment may over-run the available bandwidth of the slower link or node. If the intermediate node detects such congestion it may discard received packets from its internal queues. Such congestion may be more common where multiple transmitters attempt to forward packets through a common segment or node. However, even a single node may generate and transmit packets so quickly that it may, alone, utilize all available bandwidth. Such saturation of the communication medium can cause packet loss if the receiving intermediate node(s) or segment(s) cannot process the received packets quickly enough.
- When packets are lost, TCP/IP and other common protocols may cause retransmission of packets that were lost and all subsequent packets from that point forward (in the sequence of transmitted packets). Such retransmissions are costly in terms of elapsed time to complete the desired transmission and in terms of bandwidth utilization since information (packets) previously transmitted must be transmitted again. In some presently known protocols (such as the so-called Reno version of TCP/IP), the sender determines that a packet has been missed by the receiving node when the sending node receive three consecutive acknowledgement messages (i.e., TCP/IP ACK messages) each indicating a duplicate sequence ID value.
- To avoid such costly packet loss and the associated retransmissions, present TCP/IP (and other) protocols use techniques to attempt to estimate the available bandwidth on the communication medium and then to use the estimated available bandwidth to limit the transmitting node in hopes of thereby avoiding congestion and the resulting packet loss and performance degradation. Presently known techniques, such as those practiced in the present-day Reno version of the TCP/IP protocols (“Reno TCP/IP”), attempt to avoid congestion by predicting the available bandwidth of the communication medium and then limiting the transmitting node to a fixed percentage thereof RFC2581 provides specifications for the TCP/IP protocol for presently known techniques to reduce congestion packet loss and the associated packet retransmission. RFC2581 and other related TCP/IP specifications are readily available to those of ordinary skill in the art and may be found, for example, at http://www.rfc-editor.org/rfc.html. However, these presently practiced techniques predict the available bandwidth using essentially static information regarding the communication medium at a fixed point in time. Further, present techniques, such as those in Reno TCP/IP, often intentionally generate packet loss conditions in order to determine the available bandwidth on the communication medium.
- It is therefore an ongoing challenge to detect and avoid congestion on a communication network. It is a further ongoing challenge to reduce the time required to detect a lost packet and to retransmit any necessary packets in response to such detection.
- The present invention solves the above and other problems, thereby advancing the state of the useful arts, by providing improved methods and structures for detecting and avoiding network congestion and for detecting and retransmitting lost packets when required. In one aspect hereof, the available bandwidth is estimated dynamically by features hereof that continually learn the available bandwidth of the network medium based on mathematical analysis of one or more past responses from the receiving node(s). Another aspect hereof uses a curve fitting mathematical analysis of prior responses from the receiving node to permit interpolation/extrapolation techniques to predict an estimated future response. Still other aspects hereof improve the speed of detecting loss of a packet by improving the accuracy of round-trip time (“RTT”) estimates. The RTT is estimated based on measurements of the actual time to respond from previous acknowledged packet transmissions.
- A feature hereof therefore provides a method of reducing network congestion comprising the steps of: transmitting multiple packets from a sending node to a receiving node over a network communication medium at a rate no faster than a predetermined maximum packet transmission rate value; receiving multiple acknowledgements at the sending node from the receiving node; measuring a transmission performance value based on transmission of a packet of the multiple packets and a corresponding acknowledgement of the multiple acknowledgements; predicting an available bandwidth value based on at least two transmission performance values; and adjusting the predetermined maximum packet transmission rate based on the predicted available bandwidth to reduce network congestion on the network communication medium.
- Another feature hereof provides a method for reducing re-transmission delays in a packetized network protocol comprising: measuring a time between a successful packet transmission and receipt of a corresponding acknowledgement; using the measured time as a timeout value for a subsequent packet transmission; detecting expiration of the timeout value following the transmission of the subsequent packet; and retransmitting the subsequent packet in response to detecting expiration of the timeout value.
- Another feature hereof provides a system comprising: a packet network communication medium; a first network appliance communicatively coupled to the medium; and one or more other network appliances communicatively coupled to the first networl appliance via the medium, such that the first network appliance further comprises: a predictive tuning element to dynamically predictively adapt protocol parameters of the first network appliance based on present and past measurements of throughput on the medium.
-
FIG. 1 is a block diagram of an exemplary network appliance enhanced in accordance with features and aspects hereof. -
FIG. 2 is a flowchart describing an exemplary method for tuning retransmission parameters in accordance with features and aspects hereof. -
FIG. 3 is a flowchart describing an exemplary method for applying dynamically tuned retransmission parameters in accordance with features and aspects hereof. -
FIG. 4 is a flowchart describing an exemplary method for operating a TCP transmitter in accordance with features and aspects hereof. -
FIG. 5 is a flowchart describing an exemplary method for dynamically adjusting TCP/IP parameters used by the exemplary transmitter ofFIG. 5 to reduce network congestion. -
FIG. 1 is a block diagram depicting an enhancednetwork appliance 100 coupled to twoother network appliances network communication medium 150. Packetnetwork communication medium 150 may be any appropriate packet switched network communication medium and protocol appropriate for the particular application. For example,medium 150 maybe a TCP/IP network protocol applied to an Ethernet communication medium.Network appliance 100 maybe any node or computing device adapted for coupling to such a packetnetwork communication medium 150. For example,network appliance 100 may be a personal computer or workstation or any network appliance including bridges, routers, hubs, etc. -
Network appliance 100 includespacket transmitter element 106 andpacket receiver element 108 for transmitting and receiving packets, respectively, viamedia 150.Packet processing element 110 generates packets to be transmitted viapacket transmitter 106 and reconstructs buffers of data from received packets received viapacket receiver element 108. - In accordance with features and aspects hereof,
network appliance 100 may also include dynamiccongestion avoidance element 102 and dynamicretransmission tuning element 104 to improve network communications capabilities of network appliance 100 (collectively or individually also referred to herein as a predictive tuning element 101). Dynamicretransmission tuning element 104 is generally operable to adjust parameters of the packet transmission protocol to reduce latencies associated with retransmission of a failed or lost packet. Dynamiccongestion avoidance element 102 also tunes parameters of the packet protocol to reduce the possibility of congestion generated bynetwork appliance 100 on thecommunication medium 150. By reducing the possibility of such congestion on thecommunication medium 150, enhancednetwork appliance 100 improves overall system performance by reducing the number of occurrences of lost packets and associated, time consuming, packet retransmissions. In addition, by dynamically tuning the retransmission related protocol parameters, latencies associated with the occasional need for retransmission may be reduced thereby further improving overall system performance. -
FIG. 2 is a flowchart describing an exemplary method associated with features and aspects hereof operable to dynamically tune protocol parameters to reduce the latencies associated with packet retransmission. As applied to TCP/IP protocols, the exemplary method is adapted to measure the time between transmission of a packet and receipt of a corresponding acknowledgement message (“ACK”) for the transmitted packet. The round trip time TCP/IP parameter (“RTT”) is then set to the measured elapsed time between packet transmission and receipt of a corresponding acknowledgement. More specifically,element 200 is operable to start a timer following detection of a packet transmission by transmitting elements of the associated network appliance.Element 202 then loops, awaiting detection of the ACK message corresponding to the transmitted packet. - Upon receipt of the corresponding ACK message, element 203 is operable to estimate the next RTT value based on the elapsed time between the packet transmission and the corresponding ACK receipt. The next RTT value may be predicted as a function of the current throughput value (computed from the measured time interval) and previous measured values. As discussed further herein below, a cubic spline function may be used such that the next RTT value may be extrapolated from the current RTT estimated value and one or more past measured values. Using the predicted next RTT value so determined,
element 204 next sets RTT to the predicted next value. The method ofFIG. 2 thus may dynamically adjust the RTT TCP/IP parameter value according to measured and extrapolated throughput values. The method ofFIG. 2 may be operable to dynamically adjust RTT in response to every packet transmission (and receipt of a corresponding ACK). Alternatively, the method that may be operable periodically in response to transmission of selected packets (and receipt of corresponding ACKs). - While prior techniques used a coarse timer value to conservatively overestimate the round trip time of packet exchange, features and aspects hereof more accurately estimate RTT based on current and past actual measurements of elapsed times between packet transmission and receipt of a corresponding ACID message. Such dynamically adjust RTT values using improved accuracy in the estimation of the actual throughput enhances the time required for detection of the need to retransmit a packet.
-
FIG. 3 is a flowchart describing exemplary enhanced operation of a network appliance to utilize the dynamically tuned retransmission parameters to reduce the latencies associated with lost packet retransmission.Element 300 is first operable to initiate transmission of a packet.Element 302 then starts a timer with the RTT timeout value most recently determined.Element 304 determines whether any ACK message has been received. When any ACK message is received,element 306 is operable to determine whether the ACK message acknowledges the packet transmitted atelement 300. If so, transmission of the packet is successful and the method completes normally. If the received ACK does not acknowledge the transmitted packet,element 308 is next operable to determine whether the RTT timeout period has expired. If not, the method continues looping back toelement 304 to await receipt of yet another acknowledgement message. Ifelement 308 determines that the RTT timeout period has expired,element 310 determines whether the received acknowledgement message is a duplicate acknowledgement message (i.e., duplicating a preceding received acknowledgement message). - If the acknowledgement message is not a duplicate ACK, processing continues looping back to the
element 304 to await receipt of another acknowledgement message. Ifelement 310 determines that the received ACK is a duplicate ACK, indicating likely loss of a transmitted packet, element 312 is then operable to commence retransmission processing. - By comparison with presently practiced retransmission techniques, features and aspects hereof reduce the delay in determining that a retransmission must occur. Where prior techniques (as documented in, for example, RFC2581) awaited receipt of three duplicate ACK messages, features and aspects hereof my detect the need to transmit by waiting for two duplicate ACK messages and the expiration of the RTT timeout period. Since the RTT timeout period is dynamically adjusted by features and aspects hereof, the timeout may be tuned to an optimal or near optimal value. Thus, features and aspects hereof may notably reduce the time required to detect the need for a retransmission of a previously sent packet.
-
FIG. 4 is a flowchart describing operation of a transmitter element of a network appliance enhanced with features and aspects hereof to reduce network congestion.Element 400 is operable to initialize transmission related parameters of the packet protocol. For example, as applied to TCP/IP protocol exchanges, “ssthresh” (slow start threshold) and “cwnd” (congestion window) are initialized according to the standards of the “slow start” mode of TCP/IP protocol specifications (such as in RFC2581).Element 402 then commences transmission operation using the slow start TCP IP mode until an appropriate equilibrium state is achieved (i.e., when cwnd first exceeds ssthresh in accordance with RFC2581). When slow start transmission mode finely achieves an appropriate equilibrium,element 404 is operable to commence normal transmit operation in accordance with enhanced congestion avoidance features and aspects hereof. In general, previously known techniques achieve an equilibrium status and then, when a packet loss is detected and a corresponding retransmission initiated, reverts again to slow start mode. By contrast, features and aspects hereof enhance congestion avoidance techniques by dynamically measuring actual throughput performance on the network medium and predicting future performance therefrom. The predicted future performance may then be used to periodically and dynamically adjust the cwnd congestion avoidance TCP/IP parameter to reduce the possibility of congestion on the network medium. - In particular, during enhanced congestion avoidance operation mode initiated by
element 404,elements Element 410 then determines whether congestion has been detected on the network as reflected by a lost packet and the need for a corresponding packet retransmission. If no such congestion and corresponding retransmission is detected, processing continues in the enhanced congestion avoidance mode of operation.Elements element 410 as reflected in packet loss and corresponding retransmission, processing continues by looping back toelement 402 to reinitialize the TCP/IP transmitter of the enhanced appliance and to restart transmission using the “slow stall” mode of operation specified by TCP/IP protocol standards. - In view of the improved accuracy in estimating the available bandwidth for transmission throughput, the method of
FIG. 4 will rarely encounter congestion by operation ofelement 410. In other words, the method ofFIG. 4 improves congestion avoidance such that congestion occurs less frequently and hence is rarely detected. The iterative operation ofelements -
FIG. 5 is a flow chart describing an exemplary performance measurement method in accordance with features and aspects hereof. In general, performance is measured by counting events or timing events relating to aspects of the communication medium operation between transmission of a packet and receipt of a corresponding acknowledgement message for the transmitted packet. In general, a packet pair algorithm may be applied to this measurement. In general, the packet pair algorithm relies on the presumption that if two packets to be transmitted are queued next to one another in a queue at a link/node representing the performance bottleneck in communications, the two packets will exit that link in a predictable manner. The time between the two packet transmissions is computable in accordance with the measured performance of the bottleneck link and the known packet size. Specifically, the bandwidth of the bottleneck link (Bbln) between two nodes can be measured as:
Bbln=S(t2−t1) - Where S is the packet size and t1 and t2 are the absolute times of arrival of two acknowledgement messages: t1 corresponding to the arrival of the ACK for the first packet and t2 corresponding to the arrival of the ACK for the second packet.
- Alternatively, bandwidth may be measured by counting the number of packets of equal size transmitted before receiving an acknowledgement for a first of a sequence of such packets.
- Having so computed the Bbln from the time difference between arrival of two acknowledgement messages or from the count of the number of packets sent before receiving an acknowledgement for a particular transmitted packet, the future performance of the communication medium may be extrapolated from this current performance measurement and past measurements. The next cwnd parameter value may then be computed as the previous value plus or minus any incremental value. The incremental value may be determined as the minimum of a value computed from the predicted next throughput value and a value determined by exponential or linear increases dictated by the slow start standard congestion avoidance techniques. More specifically, the cwnd may be dynamically, periodically adjusted as:
next_cwnd=prev_cwnd+min((predicted_throughput−previous_throughput)/segment_size), (exponential or linear increase depending on proximity to ssthresh)) - In other words, if the current throughput is near the ssthresh TPC/IP parameter value (slow start threshold), then the congestion window (cwnd TCP/IP parameter value) is adjusted by the lesser of the next predicted throughput value and the linear increase value as normally utilized in slow start processing. If the current throughput is far from ssthresh, then cwnd is adjusted by the lesser of the next predicted throughput value and the exponential increase value as normally utilized in congestion avoidance processing. This aspect hereof-helps adjust the congestion window (cwnd) to adapt to the actual, present throughput while adjusting more rapidly or more slowly to adhere to present TCP/IP slow start processing standards. As noted above, the RTT TCP/IP parameter could be similarly adapted based on current and previous throughput measurements and extrapolated values.
- Returning to
FIG. 5 , element, 500 is operable to await detection of a packet transmission by the packet transmitter element described above. Upon detection of transmission of a packet,element 502 is next operable to start an appropriate timer or counter to measure the desired performance parameter. As noted above, performance may be measured in accordance with the time between receipt of consecutive acknowledgement messages or as a function of the number of packets transmitted between the transmission of a first packet and receipt of the acknowledgement corresponding to that first packet. The timer or counter then continues whileelement 504 awaits detection of an appropriate acknowledgement message. Upon such detection, element 506 and then determines the final time or count value as measured from the start of the measurement atelement 502 until detection of the relevant acknowledgement message atelement 504.Element 508 then determines an appropriate performance measurement from the final time work and value measured by element 506. Element 510 is operable to predict the next performance measure from the current and previous performance measurement values. In one exemplary embodiment hereof, a cubic spline function may be applied to predict a next performance value from current and previous performance and values as follows: - The cubic spline extrapolation is based on fitting a cubic function curve through all the points of a given set. Given a function Yi=f(Xi), i=1 . . . N, and given an interval [Xi, Mi+1], the cubic function is given by the formula:
Y=AYi+BYi+1+CY″i+DY″i+1
Where A=(Xi+1−X)/(Xi+1−Xi)
B=(X−Xi)/(Xi+1−Xi)
C=⅙(A 3 −A)(Xi+1−Xi)2
D=⅙(B 3 −B)(Xi+1−Xi)2 - And the second derivatives Y′ of the curve are given by:
((Xi−Xi−1)*Y″i−1)/6+((Xi+1−Xi−1)*Y″i)/3+((Xi+1−Xi)*Y″i+1)/6=(Yi+1−Yi)/(Xi+1−Xi)−(Yi−Yi−1)/(Xi−Xi−1)
after deriving the value of the function, it can be used to determine the value of any point within or outside the interval. -
Element 512 is then operable to adjust the TCP/IP transmitter's cwnd parameter based on the predicted next performance measurement. Processing then continues looping back toelement 500 to await a next packet transmission. The method ofFIG. 5 may be operable to dynamically adjust cwnd in response to every packet transmission. Alternatively, the method that may be operable periodically in response to transmission of selected packets. - By so periodically measuring and adjusting performance related values of the TCP/IP transmitter, the sending node may reduce potential for congestion on the network medium and thereby improve overall system performance by reducing potential for packet loss and associated retransmission.
- Those of ordinary skill in the art will readily recognize numerous functionally equivalent techniques for providing the desired dynamic adjustment to packet protocol transmission parameters to reduce potential for packet loss due to congestion and to reduce the latencies associated with packet retransmission when required. The particular exemplary methods and functions depicted herein may be implemented as one or more threads in a multithreaded or event driven programming paradigm. Such design choices are well known to those of ordinary skill in the art. Further, the methods and features and aspects described herein may be implemented in suitably programmed instructions for programmable devices as well as customized application specific integrated circuitry. Equivalency of such hardware, firmware and software designs and the performance and cost related tradeoffs associated with each represent well known design choices to those of ordinary skill in the art.
- While the invention has been illustrated and described in the drawings and foregoing description, such illustration and description is to be considered as exemplary and not restrictive in character. One embodiment of the invention and minor variants thereof have been shown and described. Protection is desired for all changes and modifications that come within the spirit of the invention. Those skilled in the art will appreciate variations of the above-described embodiments that fall within the scope of the invention. In particular, those of ordinary skill in the art will readily recognize that features and aspects hereof may be implemented equivalently in electronic circuits or as suitably programmed instructions of a general or special purpose processor. Such equivalency of circuit and programming designs is well known to those skilled in the art as a matter of design choice. As a result, the invention is not limited to the specific examples and illustrations discussed above, but only by the following claims and their equivalents.
Claims (28)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/923,732 US20080043621A1 (en) | 2004-01-08 | 2007-10-25 | Systems and Methods for Improving Network Performance |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/755,144 US7310682B2 (en) | 2004-01-08 | 2004-01-08 | Systems and methods for improving network performance |
US11/923,732 US20080043621A1 (en) | 2004-01-08 | 2007-10-25 | Systems and Methods for Improving Network Performance |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/755,144 Continuation US7310682B2 (en) | 2004-01-08 | 2004-01-08 | Systems and methods for improving network performance |
Publications (1)
Publication Number | Publication Date |
---|---|
US20080043621A1 true US20080043621A1 (en) | 2008-02-21 |
Family
ID=34794734
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/755,144 Expired - Fee Related US7310682B2 (en) | 2004-01-08 | 2004-01-08 | Systems and methods for improving network performance |
US11/923,732 Abandoned US20080043621A1 (en) | 2004-01-08 | 2007-10-25 | Systems and Methods for Improving Network Performance |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/755,144 Expired - Fee Related US7310682B2 (en) | 2004-01-08 | 2004-01-08 | Systems and methods for improving network performance |
Country Status (1)
Country | Link |
---|---|
US (2) | US7310682B2 (en) |
Cited By (33)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050071876A1 (en) * | 2003-09-30 | 2005-03-31 | Van Beek Petrus J. L. | Wireless video transmission system |
US20060095942A1 (en) * | 2004-10-30 | 2006-05-04 | Van Beek Petrus J | Wireless video transmission system |
US20070153916A1 (en) * | 2005-12-30 | 2007-07-05 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US20080052206A1 (en) * | 2006-08-22 | 2008-02-28 | Edwards Stephen K | System and method for billing users for communicating over a communications network |
US20080052394A1 (en) * | 2006-08-22 | 2008-02-28 | Bugenhagen Michael K | System and method for initiating diagnostics on a packet network node |
US20080049639A1 (en) * | 2006-08-22 | 2008-02-28 | Wiley William L | System and method for managing a service level agreement |
US20080192935A1 (en) * | 2005-09-06 | 2008-08-14 | Kabushiki Kaisha Toshiba | Receiver, Transmitter and Communication Control Program |
US20080212480A1 (en) * | 2007-02-02 | 2008-09-04 | Nec Corporation | Communication terminal which perform low-delay communication by using a broadband line |
US20090213744A1 (en) * | 2008-02-27 | 2009-08-27 | Phoenix Contact Gmbh & Co. Kg | Self-testing communications device |
US20120320784A1 (en) * | 2006-08-22 | 2012-12-20 | Embarq Holdings Company, Llc | System and method for generating a graphical user interface representative of network performance |
US8811160B2 (en) | 2006-08-22 | 2014-08-19 | Centurylink Intellectual Property Llc | System and method for routing data on a packet network |
US20140304425A1 (en) * | 2013-04-06 | 2014-10-09 | Citrix Systems, Inc. | Systems and methods for tcp westwood hybrid approach |
US8879391B2 (en) | 2008-04-09 | 2014-11-04 | Centurylink Intellectual Property Llc | System and method for using network derivations to determine path states |
US8976665B2 (en) | 2006-06-30 | 2015-03-10 | Centurylink Intellectual Property Llc | System and method for re-routing calls |
US9014204B2 (en) | 2006-08-22 | 2015-04-21 | Centurylink Intellectual Property Llc | System and method for managing network communications |
US9042370B2 (en) | 2006-08-22 | 2015-05-26 | Centurylink Intellectual Property Llc | System and method for establishing calls over a call path having best path metrics |
US9054986B2 (en) | 2006-08-22 | 2015-06-09 | Centurylink Intellectual Property Llc | System and method for enabling communications over a number of packet networks |
US9054915B2 (en) | 2006-06-30 | 2015-06-09 | Centurylink Intellectual Property Llc | System and method for adjusting CODEC speed in a transmission path during call set-up due to reduced transmission performance |
US9094257B2 (en) | 2006-06-30 | 2015-07-28 | Centurylink Intellectual Property Llc | System and method for selecting a content delivery network |
US9094261B2 (en) | 2006-08-22 | 2015-07-28 | Centurylink Intellectual Property Llc | System and method for establishing a call being received by a trunk on a packet network |
US9225646B2 (en) | 2006-08-22 | 2015-12-29 | Centurylink Intellectual Property Llc | System and method for improving network performance using a connection admission control engine |
US9225609B2 (en) | 2006-08-22 | 2015-12-29 | Centurylink Intellectual Property Llc | System and method for remotely controlling network operators |
US9241277B2 (en) | 2006-08-22 | 2016-01-19 | Centurylink Intellectual Property Llc | System and method for monitoring and optimizing network performance to a wireless device |
US9253661B2 (en) | 2006-08-22 | 2016-02-02 | Centurylink Intellectual Property Llc | System and method for modifying connectivity fault management packets |
US9419869B2 (en) | 2008-12-04 | 2016-08-16 | Centurylink Intellectual Property Llc | Indicating performance information to a user to improve communications |
US9521150B2 (en) | 2006-10-25 | 2016-12-13 | Centurylink Intellectual Property Llc | System and method for automatically regulating messages between networks |
US9602265B2 (en) | 2006-08-22 | 2017-03-21 | Centurylink Intellectual Property Llc | System and method for handling communications requests |
US9621361B2 (en) | 2006-08-22 | 2017-04-11 | Centurylink Intellectual Property Llc | Pin-hole firewall for communicating data packets on a packet network |
US9661514B2 (en) | 2006-08-22 | 2017-05-23 | Centurylink Intellectual Property Llc | System and method for adjusting communication parameters |
US9660761B2 (en) | 2006-10-19 | 2017-05-23 | Centurylink Intellectual Property Llc | System and method for monitoring a connection of an end-user device to a network |
US9832090B2 (en) | 2006-08-22 | 2017-11-28 | Centurylink Intellectual Property Llc | System, method for compiling network performancing information for communications with customer premise equipment |
US10075351B2 (en) | 2006-08-22 | 2018-09-11 | Centurylink Intellectual Property Llc | System and method for improving network performance |
US10374958B2 (en) * | 2015-06-08 | 2019-08-06 | Samsung Electronics Co., Ltd. | Method and apparatus for TCP-based transmission control in communication system |
Families Citing this family (51)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7940796B2 (en) * | 2004-02-27 | 2011-05-10 | Research In Motion Limited | System and method for delivery of packets |
US7397759B2 (en) * | 2004-03-15 | 2008-07-08 | Microsoft Corporation | Response for spurious timeout |
US8930569B2 (en) * | 2004-05-05 | 2015-01-06 | Qualcomm Incorporated | Methods and apparatus for optimum file transfers in a time-varying network emvironment |
WO2005125116A1 (en) * | 2004-06-22 | 2005-12-29 | Telefonaktiebolaget Lm Ericsson (Publ) | Network feedback method and device |
US7573886B1 (en) * | 2004-07-06 | 2009-08-11 | Sun Microsystems, Inc. | System and method for adaptive bandwidth determination |
US7577097B2 (en) * | 2005-03-22 | 2009-08-18 | Microsoft Corporation | Compound transmission control protocol |
US8909807B2 (en) * | 2005-04-07 | 2014-12-09 | Opanga Networks, Inc. | System and method for progressive download using surplus network capacity |
US7500010B2 (en) * | 2005-04-07 | 2009-03-03 | Jeffrey Paul Harrang | Adaptive file delivery system and method |
US9065595B2 (en) | 2005-04-07 | 2015-06-23 | Opanga Networks, Inc. | System and method for peak flow detection in a communication network |
US11258531B2 (en) | 2005-04-07 | 2022-02-22 | Opanga Networks, Inc. | System and method for peak flow detection in a communication network |
US8589508B2 (en) * | 2005-04-07 | 2013-11-19 | Opanga Networks, Inc. | System and method for flow control in an adaptive file delivery system |
US8719399B2 (en) | 2005-04-07 | 2014-05-06 | Opanga Networks, Inc. | Adaptive file delivery with link profiling system and method |
EP1917631A1 (en) * | 2005-08-25 | 2008-05-07 | International Business Machines Corporation | Method and system for displaying performance constraints in a flow design tool |
US20070223477A1 (en) * | 2006-03-27 | 2007-09-27 | Eidson John C | Packet recognizer with hardware/software tradeoff |
US20080049635A1 (en) * | 2006-08-25 | 2008-02-28 | Sbc Knowledge Ventures, Lp | Method and system for determining one-way packet travel time using RTCP |
US20080176554A1 (en) * | 2007-01-16 | 2008-07-24 | Mediacast, Llc | Wireless data delivery management system and method |
US7865610B2 (en) * | 2007-03-12 | 2011-01-04 | Nautel Limited | Point to multipoint reliable protocol for synchronous streaming data in a lossy IP network |
US20100027966A1 (en) * | 2008-08-04 | 2010-02-04 | Opanga Networks, Llc | Systems and methods for video bookmarking |
JP2012503255A (en) * | 2008-09-18 | 2012-02-02 | オパンガ ネットワークス インコーポレイテッド | System and method for automatic detection and adapted delivery of high-load media content |
KR20110082192A (en) * | 2008-11-07 | 2011-07-18 | 오팡가 네트웍스, 인크. | Portable data storage devices that initiate data transfers utilizing host devices |
WO2010068497A2 (en) * | 2008-11-25 | 2010-06-17 | Jeffrey Harrang | Viral distribution of digital media content over social networks |
US8406133B2 (en) * | 2009-02-24 | 2013-03-26 | Silver Spring Networks, Inc. | System and method of regulating a packet rate to optimize traffic in a network |
US8886790B2 (en) * | 2009-08-19 | 2014-11-11 | Opanga Networks, Inc. | Systems and methods for optimizing channel resources by coordinating data transfers based on data type and traffic |
KR101689778B1 (en) | 2009-08-19 | 2016-12-27 | 오팡가 네트웍스, 인크. | Enhanced data delivery based on real time analysis of network communications quality and traffic |
WO2011022094A1 (en) * | 2009-08-20 | 2011-02-24 | Opanga Networks, Inc | Broadcasting content using surplus network capacity |
TWI492574B (en) * | 2010-02-05 | 2015-07-11 | Realtek Semiconductor Corp | A method of detecting status of remote device and/or transmission control in communication system |
US9178949B2 (en) * | 2010-03-03 | 2015-11-03 | Blackberry Limited | Method, system and apparatus for managing push data transfers |
US8495196B2 (en) | 2010-03-22 | 2013-07-23 | Opanga Networks, Inc. | Systems and methods for aligning media content delivery sessions with historical network usage |
US10122599B2 (en) | 2012-10-19 | 2018-11-06 | Airmagnet, Inc. | Method and apparatus for dynamically scaling application performance analysis completeness based on available system resources |
CN104184794B (en) * | 2013-05-27 | 2019-01-08 | 韩国电子通信研究院 | Data package size method of randomization |
CN103327032B (en) * | 2013-07-11 | 2016-06-15 | 中国科学院微电子研究所 | Detection method for internet of things packet discarding attack and internet of things tree system |
US20150055482A1 (en) * | 2013-08-20 | 2015-02-26 | Brocade Communications Systems, Inc. | TCP Extended Fast Recovery and Segment Timing |
CN105763474B (en) * | 2014-12-19 | 2019-10-25 | 华为技术有限公司 | Data transmission method and device |
US9756112B2 (en) | 2015-02-11 | 2017-09-05 | At&T Intellectual Property I, L.P. | Method and system for managing service quality according to network status predictions |
WO2017000117A1 (en) * | 2015-06-29 | 2017-01-05 | 华为技术有限公司 | Method for data processing and receiver device |
US10282687B2 (en) | 2015-10-07 | 2019-05-07 | University Of Utah Research Foundation | Systems and methods for managing power generation resources |
US10296030B2 (en) | 2015-10-07 | 2019-05-21 | University Of Utah Research Foundation | Systems and methods for power system management |
US10509374B2 (en) | 2015-10-07 | 2019-12-17 | University Of Utah Research Foundation | Systems and methods for managing power generation and storage resources |
JP2017079412A (en) * | 2015-10-20 | 2017-04-27 | 富士通株式会社 | Packet analysis program, packet analysis device, and packet analysis method |
EP3406034B1 (en) * | 2016-01-20 | 2019-07-10 | Telefonaktiebolaget LM Ericsson (publ) | Methods, system and user equipment of a wireless communication network for determining transmission conditions for a real-time media flow |
US20170324642A1 (en) * | 2016-05-04 | 2017-11-09 | Microsoft Technology Licensing, Llc | Initial and periodic slowdowns for background connections |
US10536364B2 (en) * | 2017-04-06 | 2020-01-14 | Rohde & Schwarz Gmbh & Co. Kg | Protocol test device and method for operating a protocol test device |
US10567264B2 (en) | 2017-04-06 | 2020-02-18 | Rohde & Schwarz Gmbh & Co. Kg | Protocol test device and method for operating a protocol test device |
US10693575B2 (en) | 2018-08-31 | 2020-06-23 | At&T Intellectual Property I, L.P. | System and method for throughput prediction for cellular networks |
US10841231B2 (en) * | 2018-11-15 | 2020-11-17 | Mellanox Technologies, Ltd. | Transmission timeout system |
US10868726B2 (en) | 2018-12-07 | 2020-12-15 | At&T Intellectual Property I, L.P. | Apparatus and method for selecting a bandwidth prediction source |
US11490149B2 (en) | 2019-03-15 | 2022-11-01 | At&T Intellectual Property I, L.P. | Cap-based client-network interaction for improved streaming experience |
US11438243B2 (en) * | 2019-04-12 | 2022-09-06 | EMC IP Holding Company LLC | Adaptive adjustment of links per channel based on network metrics |
CN110120921B (en) * | 2019-05-13 | 2022-07-01 | 深圳市赛为智能股份有限公司 | Congestion avoidance method, apparatus, computer device and storage medium |
US11233715B1 (en) * | 2020-07-14 | 2022-01-25 | Juniper Networks, Inc. | Dynamic prediction and management of application service level agreements |
EP3964981A1 (en) * | 2020-09-08 | 2022-03-09 | Atos Integration | Method for optimising the space for storing a messaging server and associated system |
Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5890014A (en) * | 1996-08-05 | 1999-03-30 | Micronet Technology, Inc. | System for transparently identifying and matching an input/output profile to optimal input/output device parameters |
US5926462A (en) * | 1995-11-16 | 1999-07-20 | Loran Network Systems, Llc | Method of determining topology of a network of objects which compares the similarity of the traffic sequences/volumes of a pair of devices |
US6075821A (en) * | 1997-12-16 | 2000-06-13 | Integrated Telecom Express | Method of configuring and dynamically adapting data and energy parameters in a multi-channel communications system |
US6141565A (en) * | 1997-11-13 | 2000-10-31 | Metawave Communications Corporation | Dynamic mobile parameter optimization |
US6178450B1 (en) * | 1997-07-01 | 2001-01-23 | Kokusai Denshin Denwa Co., Ltd. | Method and apparatus for monitoring a communication link based on TCP/IP protocol by emulating behavior of the TCP protocol |
US20020150048A1 (en) * | 2001-04-12 | 2002-10-17 | Sungwon Ha | Data transport acceleration and management within a network communication system |
US20040032835A1 (en) * | 1999-12-30 | 2004-02-19 | Aperto Networks, Inc | Integrated,self-optimizing,multi-parameter/multi-variable point-to-multipoint communication system [II] |
US20050012749A1 (en) * | 2003-07-15 | 2005-01-20 | Nelson Gonzalez | Multiple parallel processor computer graphics system |
US20050076115A1 (en) * | 2003-09-24 | 2005-04-07 | Dell Products L.P. | Dynamically varying a raid cache policy in order to optimize throughput |
US20050144303A1 (en) * | 2002-04-12 | 2005-06-30 | Dongmei Zhang | System, device and method for improving throughput in a communication network, preferably a mobile ipv6-based network |
US20050237929A1 (en) * | 2004-04-21 | 2005-10-27 | National University Of Ireland Maynooth | Congestion control in data networks |
US7187669B1 (en) * | 2002-10-03 | 2007-03-06 | Juniper Networks, Inc. | Contention management techniques for reservation-based TDMA systems |
US7447145B2 (en) * | 2003-05-27 | 2008-11-04 | Nec Corporation | Data communication device selecting modulation method with an appropriate threshold value in adaptive modulation |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5167035A (en) * | 1988-09-08 | 1992-11-24 | Digital Equipment Corporation | Transferring messages between nodes in a network |
US5627970A (en) * | 1994-08-08 | 1997-05-06 | Lucent Technologies Inc. | Methods and apparatus for achieving and maintaining optimum transmission rates and preventing data loss in a processing system nework |
US5848266A (en) * | 1996-06-20 | 1998-12-08 | Intel Corporation | Dynamic data rate adjustment to maintain throughput of a time varying signal |
US5784569A (en) * | 1996-09-23 | 1998-07-21 | Silicon Graphics, Inc. | Guaranteed bandwidth allocation method in a computer system for input/output data transfers |
US6105064A (en) * | 1997-05-30 | 2000-08-15 | Novell, Inc. | System for placing packets on network for transmission from sending endnode to receiving endnode at times which are determined by window size and metering interval |
US6505253B1 (en) * | 1998-06-30 | 2003-01-07 | Sun Microsystems | Multiple ACK windows providing congestion control in reliable multicast protocol |
US6308214B1 (en) * | 1998-09-23 | 2001-10-23 | Inktomi Corporation | Self-tuning dataflow I/O core |
US20010010059A1 (en) * | 1998-10-28 | 2001-07-26 | Steven Wesley Burman | Method and apparatus for determining travel time for data sent between devices connected to a computer network |
US6462742B1 (en) * | 1999-08-05 | 2002-10-08 | Microsoft Corporation | System and method for multi-dimensional motion interpolation using verbs and adverbs |
US20030023746A1 (en) * | 2001-07-26 | 2003-01-30 | Koninklijke Philips Electronics N.V. | Method for reliable and efficient support of congestion control in nack-based protocols |
EP1286349A1 (en) * | 2001-08-21 | 2003-02-26 | Canal+ Technologies Société Anonyme | File and content management |
-
2004
- 2004-01-08 US US10/755,144 patent/US7310682B2/en not_active Expired - Fee Related
-
2007
- 2007-10-25 US US11/923,732 patent/US20080043621A1/en not_active Abandoned
Patent Citations (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5926462A (en) * | 1995-11-16 | 1999-07-20 | Loran Network Systems, Llc | Method of determining topology of a network of objects which compares the similarity of the traffic sequences/volumes of a pair of devices |
US5890014A (en) * | 1996-08-05 | 1999-03-30 | Micronet Technology, Inc. | System for transparently identifying and matching an input/output profile to optimal input/output device parameters |
US6178450B1 (en) * | 1997-07-01 | 2001-01-23 | Kokusai Denshin Denwa Co., Ltd. | Method and apparatus for monitoring a communication link based on TCP/IP protocol by emulating behavior of the TCP protocol |
US6141565A (en) * | 1997-11-13 | 2000-10-31 | Metawave Communications Corporation | Dynamic mobile parameter optimization |
US6075821A (en) * | 1997-12-16 | 2000-06-13 | Integrated Telecom Express | Method of configuring and dynamically adapting data and energy parameters in a multi-channel communications system |
US20040032835A1 (en) * | 1999-12-30 | 2004-02-19 | Aperto Networks, Inc | Integrated,self-optimizing,multi-parameter/multi-variable point-to-multipoint communication system [II] |
US20020150048A1 (en) * | 2001-04-12 | 2002-10-17 | Sungwon Ha | Data transport acceleration and management within a network communication system |
US7099273B2 (en) * | 2001-04-12 | 2006-08-29 | Bytemobile, Inc. | Data transport acceleration and management within a network communication system |
US20050144303A1 (en) * | 2002-04-12 | 2005-06-30 | Dongmei Zhang | System, device and method for improving throughput in a communication network, preferably a mobile ipv6-based network |
US7187669B1 (en) * | 2002-10-03 | 2007-03-06 | Juniper Networks, Inc. | Contention management techniques for reservation-based TDMA systems |
US7447145B2 (en) * | 2003-05-27 | 2008-11-04 | Nec Corporation | Data communication device selecting modulation method with an appropriate threshold value in adaptive modulation |
US20050012749A1 (en) * | 2003-07-15 | 2005-01-20 | Nelson Gonzalez | Multiple parallel processor computer graphics system |
US20050076115A1 (en) * | 2003-09-24 | 2005-04-07 | Dell Products L.P. | Dynamically varying a raid cache policy in order to optimize throughput |
US7487235B2 (en) * | 2003-09-24 | 2009-02-03 | Dell Products L.P. | Dynamically varying a raid cache policy in order to optimize throughput |
US20050237929A1 (en) * | 2004-04-21 | 2005-10-27 | National University Of Ireland Maynooth | Congestion control in data networks |
US7394762B2 (en) * | 2004-04-21 | 2008-07-01 | National University Of Ireland Maynooth | Congestion control in data networks |
Cited By (56)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050071876A1 (en) * | 2003-09-30 | 2005-03-31 | Van Beek Petrus J. L. | Wireless video transmission system |
US9325998B2 (en) | 2003-09-30 | 2016-04-26 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US8356327B2 (en) * | 2004-10-30 | 2013-01-15 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US20060095942A1 (en) * | 2004-10-30 | 2006-05-04 | Van Beek Petrus J | Wireless video transmission system |
US20080192935A1 (en) * | 2005-09-06 | 2008-08-14 | Kabushiki Kaisha Toshiba | Receiver, Transmitter and Communication Control Program |
US8190891B2 (en) * | 2005-09-06 | 2012-05-29 | Kabushiki Kaisha Toshiba | Receiver, transmitter and communication control program |
US20070153916A1 (en) * | 2005-12-30 | 2007-07-05 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US9544602B2 (en) | 2005-12-30 | 2017-01-10 | Sharp Laboratories Of America, Inc. | Wireless video transmission system |
US9549004B2 (en) | 2006-06-30 | 2017-01-17 | Centurylink Intellectual Property Llc | System and method for re-routing calls |
US10560494B2 (en) | 2006-06-30 | 2020-02-11 | Centurylink Intellectual Property Llc | Managing voice over internet protocol (VoIP) communications |
US9749399B2 (en) | 2006-06-30 | 2017-08-29 | Centurylink Intellectual Property Llc | System and method for selecting a content delivery network |
US9838440B2 (en) | 2006-06-30 | 2017-12-05 | Centurylink Intellectual Property Llc | Managing voice over internet protocol (VoIP) communications |
US9054915B2 (en) | 2006-06-30 | 2015-06-09 | Centurylink Intellectual Property Llc | System and method for adjusting CODEC speed in a transmission path during call set-up due to reduced transmission performance |
US10230788B2 (en) | 2006-06-30 | 2019-03-12 | Centurylink Intellectual Property Llc | System and method for selecting a content delivery network |
US9154634B2 (en) | 2006-06-30 | 2015-10-06 | Centurylink Intellectual Property Llc | System and method for managing network communications |
US9118583B2 (en) | 2006-06-30 | 2015-08-25 | Centurylink Intellectual Property Llc | System and method for re-routing calls |
US8976665B2 (en) | 2006-06-30 | 2015-03-10 | Centurylink Intellectual Property Llc | System and method for re-routing calls |
US9094257B2 (en) | 2006-06-30 | 2015-07-28 | Centurylink Intellectual Property Llc | System and method for selecting a content delivery network |
US9712445B2 (en) | 2006-08-22 | 2017-07-18 | Centurylink Intellectual Property Llc | System and method for routing data on a packet network |
US9813320B2 (en) | 2006-08-22 | 2017-11-07 | Centurylink Intellectual Property Llc | System and method for generating a graphical user interface representative of network performance |
US9042370B2 (en) | 2006-08-22 | 2015-05-26 | Centurylink Intellectual Property Llc | System and method for establishing calls over a call path having best path metrics |
US9014204B2 (en) | 2006-08-22 | 2015-04-21 | Centurylink Intellectual Property Llc | System and method for managing network communications |
US9094261B2 (en) | 2006-08-22 | 2015-07-28 | Centurylink Intellectual Property Llc | System and method for establishing a call being received by a trunk on a packet network |
US9112734B2 (en) * | 2006-08-22 | 2015-08-18 | Centurylink Intellectual Property Llc | System and method for generating a graphical user interface representative of network performance |
US20080052206A1 (en) * | 2006-08-22 | 2008-02-28 | Edwards Stephen K | System and method for billing users for communicating over a communications network |
US10469385B2 (en) | 2006-08-22 | 2019-11-05 | Centurylink Intellectual Property Llc | System and method for improving network performance using a connection admission control engine |
US10348594B2 (en) | 2006-08-22 | 2019-07-09 | Centurylink Intellectual Property Llc | Monitoring performance of voice over internet protocol (VoIP) networks |
US9225646B2 (en) | 2006-08-22 | 2015-12-29 | Centurylink Intellectual Property Llc | System and method for improving network performance using a connection admission control engine |
US9225609B2 (en) | 2006-08-22 | 2015-12-29 | Centurylink Intellectual Property Llc | System and method for remotely controlling network operators |
US9240906B2 (en) | 2006-08-22 | 2016-01-19 | Centurylink Intellectual Property Llc | System and method for monitoring and altering performance of a packet network |
US9241277B2 (en) | 2006-08-22 | 2016-01-19 | Centurylink Intellectual Property Llc | System and method for monitoring and optimizing network performance to a wireless device |
US9253661B2 (en) | 2006-08-22 | 2016-02-02 | Centurylink Intellectual Property Llc | System and method for modifying connectivity fault management packets |
US8811160B2 (en) | 2006-08-22 | 2014-08-19 | Centurylink Intellectual Property Llc | System and method for routing data on a packet network |
US20080052394A1 (en) * | 2006-08-22 | 2008-02-28 | Bugenhagen Michael K | System and method for initiating diagnostics on a packet network node |
US9479341B2 (en) | 2006-08-22 | 2016-10-25 | Centurylink Intellectual Property Llc | System and method for initiating diagnostics on a packet network node |
US10075351B2 (en) | 2006-08-22 | 2018-09-11 | Centurylink Intellectual Property Llc | System and method for improving network performance |
US20120320784A1 (en) * | 2006-08-22 | 2012-12-20 | Embarq Holdings Company, Llc | System and method for generating a graphical user interface representative of network performance |
US9992348B2 (en) | 2006-08-22 | 2018-06-05 | Century Link Intellectual Property LLC | System and method for establishing a call on a packet network |
US9602265B2 (en) | 2006-08-22 | 2017-03-21 | Centurylink Intellectual Property Llc | System and method for handling communications requests |
US9621361B2 (en) | 2006-08-22 | 2017-04-11 | Centurylink Intellectual Property Llc | Pin-hole firewall for communicating data packets on a packet network |
US9660917B2 (en) | 2006-08-22 | 2017-05-23 | Centurylink Intellectual Property Llc | System and method for remotely controlling network operators |
US9661514B2 (en) | 2006-08-22 | 2017-05-23 | Centurylink Intellectual Property Llc | System and method for adjusting communication parameters |
US20080049639A1 (en) * | 2006-08-22 | 2008-02-28 | Wiley William L | System and method for managing a service level agreement |
US9832090B2 (en) | 2006-08-22 | 2017-11-28 | Centurylink Intellectual Property Llc | System, method for compiling network performancing information for communications with customer premise equipment |
US9054986B2 (en) | 2006-08-22 | 2015-06-09 | Centurylink Intellectual Property Llc | System and method for enabling communications over a number of packet networks |
US9806972B2 (en) | 2006-08-22 | 2017-10-31 | Centurylink Intellectual Property Llc | System and method for monitoring and altering performance of a packet network |
US9660761B2 (en) | 2006-10-19 | 2017-05-23 | Centurylink Intellectual Property Llc | System and method for monitoring a connection of an end-user device to a network |
US9521150B2 (en) | 2006-10-25 | 2016-12-13 | Centurylink Intellectual Property Llc | System and method for automatically regulating messages between networks |
US20080212480A1 (en) * | 2007-02-02 | 2008-09-04 | Nec Corporation | Communication terminal which perform low-delay communication by using a broadband line |
US8004985B2 (en) * | 2007-02-02 | 2011-08-23 | Nec Corporation | Communication terminal which perform low-delay communication by using a broadband line |
US20090213744A1 (en) * | 2008-02-27 | 2009-08-27 | Phoenix Contact Gmbh & Co. Kg | Self-testing communications device |
US8879391B2 (en) | 2008-04-09 | 2014-11-04 | Centurylink Intellectual Property Llc | System and method for using network derivations to determine path states |
US9419869B2 (en) | 2008-12-04 | 2016-08-16 | Centurylink Intellectual Property Llc | Indicating performance information to a user to improve communications |
US20140304425A1 (en) * | 2013-04-06 | 2014-10-09 | Citrix Systems, Inc. | Systems and methods for tcp westwood hybrid approach |
US9118569B2 (en) * | 2013-04-06 | 2015-08-25 | Citrix System, Inc. | Systems and methods for TCP Westwood hybrid approach |
US10374958B2 (en) * | 2015-06-08 | 2019-08-06 | Samsung Electronics Co., Ltd. | Method and apparatus for TCP-based transmission control in communication system |
Also Published As
Publication number | Publication date |
---|---|
US20050165948A1 (en) | 2005-07-28 |
US7310682B2 (en) | 2007-12-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7310682B2 (en) | Systems and methods for improving network performance | |
US7200111B2 (en) | Method for improving TCP performance over wireless links | |
Floyd et al. | TCP friendly rate control (TFRC): Protocol specification | |
US8125910B2 (en) | Communication system | |
Sinha et al. | WTCP: A reliable transport protocol for wireless wide-area networks | |
US8379535B2 (en) | Optimization of streaming data throughput in unreliable networks | |
Handley et al. | TCP friendly rate control (TFRC): Protocol specification | |
EP1793557B1 (en) | Adaptive delayed ACK switching for TCP applications | |
JP4283589B2 (en) | COMMUNICATION DEVICE, COMMUNICATION CONTROL METHOD, AND PROGRAM | |
US7099273B2 (en) | Data transport acceleration and management within a network communication system | |
US7496036B2 (en) | Method and apparatus for determining client-perceived server response time | |
US20030023746A1 (en) | Method for reliable and efficient support of congestion control in nack-based protocols | |
KR20020087940A (en) | Method for efficient retransmission timeout estimation in NACK-based protocols | |
JP2004523992A (en) | Data flow control method | |
US8416694B2 (en) | Network feedback method and device | |
Karn et al. | Improving round-trip time estimates in reliable transport protocols | |
US8565249B2 (en) | Queue management system and methods | |
TWI308012B (en) | Method for adaptive estimation of retransmission timeout in wireless communication systems | |
Carletto et al. | Shallow window reduction for congestion control under TCP | |
Premalatha et al. | Mitigating congestion in wireless networks by using TCP variants | |
Martignon | Enhanced bandwidt estimation and loss differentiation in the TCP congestion control scheme. | |
De Vleeschouwer et al. | Explicit window-based control in lossy packet networks | |
De Vleeschouwer et al. | Loss-resilient window-based congestion control | |
Widmer | INTERNET-DRAFT ICIR Intended status: Proposed Standard M. Handley Expires: July 2008 University College London J. Padhye Microsoft | |
JP2019012866A (en) | Control system, available band width estimation system, device, method and program |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: LSI CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HATIME, HICHAM;REEL/FRAME:020012/0794 Effective date: 20040107 |
|
AS | Assignment |
Owner name: LSI CORPORATION, CALIFORNIA Free format text: MERGER;ASSIGNOR:LSI SUBSIDIARY CORP.;REEL/FRAME:020548/0977 Effective date: 20070404 Owner name: LSI CORPORATION,CALIFORNIA Free format text: MERGER;ASSIGNOR:LSI SUBSIDIARY CORP.;REEL/FRAME:020548/0977 Effective date: 20070404 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |