[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

US20080043621A1 - Systems and Methods for Improving Network Performance - Google Patents

Systems and Methods for Improving Network Performance Download PDF

Info

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
Application number
US11/923,732
Inventor
Hicham Hatime
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.)
LSI Corp
Original Assignee
LSI Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by LSI Corp filed Critical LSI Corp
Priority to US11/923,732 priority Critical patent/US20080043621A1/en
Assigned to LSI CORPORATION reassignment LSI CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: HATIME, HICHAM
Assigned to LSI CORPORATION reassignment LSI CORPORATION MERGER (SEE DOCUMENT FOR DETAILS). Assignors: LSI SUBSIDIARY CORP.
Publication of US20080043621A1 publication Critical patent/US20080043621A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/11Identifying congestion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/12Avoiding congestion; Recovering from congestion
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/19Flow control; Congestion control at layers above the network layer
    • H04L47/193Flow control; Congestion control at layers above the network layer at the transport layer, e.g. TCP related
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/25Flow control; Congestion control with rate being modified by the source upon detecting a change of network conditions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/28Flow control; Congestion control in relation to timing considerations
    • H04L47/283Flow control; Congestion control in relation to timing considerations in response to processing delays, e.g. caused by jitter or round trip time [RTT]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L47/00Traffic control in data switching networks
    • H04L47/10Flow control; Congestion control
    • H04L47/37Slow start
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/16Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
    • H04L69/163In-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

Systems and methods for improving network throughput in a packet ties to network communication environment. In one aspect here of, delays associated with retransmission of a packet or reduced to improve total performance and bandwidth utilization on the communication network medium. A roundtrip time parameter of TCP/IP communications networks may be adjusted according to actual measured response time of a successful packet transmission and used as a timeout value to detect a possible packet loss sooner than previous techniques. Another aspect hereof provides for dynamically adjusting estimated available bandwidth of the communication medium. The estimated available bandwidth is then useful to better avoid congestion on the medium and the resulting packet loss.

Description

    BACKGROUND OF THE INVENTION
  • 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.
  • SUMMARY OF THE INVENTION
  • 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.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • 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.
  • DETAILED DESCRIPTION OF THE DRAWINGS
  • 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. 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 packet network 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 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.
  • In accordance with features and aspects hereof, 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. 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 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).
  • 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 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. If not, the method continues looping back to element 304 to await receipt of yet another acknowledgement message. If element 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. 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.
  • 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 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. If congestion is detected by element 410 as reflected in packet loss and corresponding retransmission, 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.
  • 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 of element 410. In other words, 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. By contrast, 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. 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 while element 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 at element 502 until detection of the relevant acknowledgement message at element 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 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.
  • 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)

1. (canceled)
2. 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 said multiple packets and a corresponding acknowledgment 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,
wherein the step of predicting comprises:
determining a polynomial equation based upon the at least two transmission performance values; and
extrapolating from the polynomial equation to determine the predicted available bandwidth value.
3. The method of claim 2 wherein the step of determining comprises:
determining a cubic spline function based upon the at least two transmission performance values.
4. (canceled)
5. (canceled)
6. 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 said the subsequent packet; and
retransmitting the subsequent packet in response to detecting expiration of the timeout value.
7. The method of claim 6 further comprising:
detecting receipt of two negative acknowledgement packets,
wherein the step of retransmitting is further responsive to the detection of receipt of two negative acknowledgement packets.
8. A method for reducing TCP/IP network congestion comprising:
estimating available bandwidth on the TCP/IP network based on a positively acknowledged packet; and
responsive to the estimated available bandwidth, dynamically adjusting at least one TCP/IP transmission parameter to reduce packet loss due to network congestion.
9. The method of claim 8 wherein the TCP/IP parameters may include one or more of slow start threshold, congestion window and roundtrip time.
10. The method of claim 9 wherein the step of estimating comprises:
determining a number of additional packets transmitted between a first transmitted packet and an acknowledgement message received corresponding to the first transmitted packet.
11. The method of claim 9 wherein the step of estimating comprises:
determining a time interval between a first transmitted packet and an acknowledgement message received corresponding to the first transmitted packet.
12. The method of claim 9 wherein the step of adjusting comprises adjusting the roundtrip time.
13. The method of claim 12 further comprising:
applying the adjusted roundtrip time to reduce retransmission delays on the TCP/IP network.
14. The method of claim 13 wherein the step of applying comprises:
detecting expiration of the roundtrip time following transmission of a packet without receiving an acknowledgement; and
retransmitting the packet in response to detection of the expired roundtrip time.
15. 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 network appliance via the medium,
wherein 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.
16. The system of claim 15 wherein the predictive tuning element further comprises:
a congestion avoidance element to dynamically adapt transmission protocol parameters to avoid congestion on the medium.
17. The system of claim 16 wherein the first network appliance is a TCP/IP protocol compatible network appliance and wherein the congestion avoidance element dynamically adapts the cwnd TCP/IP parameter to avoid congestion based on current and past measurement of throughput applied to a predictive mathematical model.
18. The system of claim 17 wherein the predictive mathematical model fits a cubic spline polynomial to the present and past throughput measurements to predict future throughput and corresponding adaptation of cwnd.
19. The system of claim 15 wherein the predictive tuning element further comprises:
a retransmission element to dynamically adapt retransmission protocol parameters to reduce latencies associated with detecting packet loss on the medium.
20. The system of claim 19 wherein the first network appliance is a TCP/IP protocol compatible network appliance and wherein the retransmissions element dynamically adapts the RTT TCP/IP parameter to reduce latencies based on current and past measurement of throughput applied to a predictive mathematical model.
21. The system of claim 20 wherein the predictive mathematical model fits a cubic spline polynomial to the present and past throughput measurements to predict future throughput and corresponding adaptation of RTT.
22. (canceled)
23. A computer readable storage medium tangibly embodying program instructions to perform a method of reducing network congestion, the method 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 said multiple packets and a corresponding acknowledgment 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,
wherein the step of predicting comprises:
determining a polynomial equation based upon the at least two transmission performance values; and extrapolating from the polynomial equation to determine the predicted available bandwidth value.
24. The storage medium of claim 23 wherein the step of determining comprises:
determining a cubic spline function based upon the at least two transmission performance values.
25. (canceled)
26. (canceled)
27. 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 said the subsequent packet; and
retransmitting the subsequent packet in response to detecting expiration of the timeout value.
28. The method of claim 27 further comprising:
detecting receipt of two negative acknowledgement packets, wherein the step of retransmitting is further responsive to the detection of receipt of two negative acknowledgement packets.
US11/923,732 2004-01-08 2007-10-25 Systems and Methods for Improving Network Performance Abandoned US20080043621A1 (en)

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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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

Patent Citations (16)

* Cited by examiner, † Cited by third party
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)

* Cited by examiner, † Cited by third party
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