Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Suppose, in TCP's adaptive retransmission mechanism, that EstimatedRTT is 90 at some point and subsequent measured RTTs all are 200 . How long does it take before the TimeOut value, as calculated by the Jacobson/Karels algorithm, falls below 300 ? Assume initial Deviation value of 25 ; use \(\delta=1 / 8\).

Short Answer

Expert verified
Timeout falls below 300 after 4 or 5 RTT calculations.

Step by step solution

01

- Understand the Problem

The task is to determine how long it takes for the TimeOut value, calculated by the Jacobson/Karels algorithm, to fall below 300 given the initial conditions: EstimatedRTT is 90, measured RTTs are 200, the initial Deviation value is 25, and \(\delta=1/8\).
02

- Identify the Key Equations

The time-out calculation involves updating both the EstimatedRTT and the Deviation. The formulas are: \[ EstimatedRTT_{new} = (1 - \delta) \cdot EstimatedRTT_{old} + \delta \cdot SampleRTT \] and \[ Deviation_{new} = (1 - \delta) \cdot Deviation_{old} + \delta \cdot |SampleRTT - EstimatedRTT_{old}| \] The TimeOut value is then calculated as: \[ Timeout = EstimatedRTT + 4 \cdot Deviation \]
03

- Update on First Measurement

Using the given formulas: \[ EstimatedRTT_{1} = (1 - 1/8) \cdot 90 + (1/8) \cdot 200 = 101.25 \] \[ Deviation_{1} = (1 - 1/8) \cdot 25 + (1/8) \cdot |200 - 90| = 40.625 \] \[ Timeout_{1} = 101.25 + 4 \cdot 40.625 = 263.75 \]
04

- Update on Subsequent Measurements

Continue updating with SampleRTT = 200: \[ EstimatedRTT_{2} = (1 - 1/8) \cdot 101.25 + (1/8) \cdot 200 = 112.97 \] \[ Deviation_{2} = (1 - 1/8) \cdot 40.625 + (1/8) \cdot |200 - 101.25| = 50.54 \] \[ Timeout_{2} = 112.97 + 4 \cdot 50.54 = 315.13 \]
05

- Finding the Time to Drop Below 300

Continue until Timeout falls below 300: \[ EstimatedRTT_{3} = (1 - 1/8) \cdot 112.97 + (1/8) \cdot 200 = 123.35 \] \[ Deviation_{3} = (1 - 1/8) \cdot 50.54 + (1/8) \cdot |200 - 112.97| = 58.225 \] \[ Timeout_{3} = 123.35 + 4 \cdot 58.225 = 356.25 \] Continue updating until calculations show when Timeout falls below 300.
06

- Final Calculation

After further updates: \[ EstimatedRTT_{4} = 133.2 \] \[ Deviation_{4} = 64.47 \] \[ Timeout_{4} = 133.2 + 4 \cdot 64.47 = 391.08 \] \[ EstimatedRTT_{5} = 142.3 \] \[ Deviation_{5} = 69.265 \] \[ Timeout_{5} = 142.3 + 4 \cdot 69.265 = 419.36 \] After more iterations: \[ EstimatedRTT_{6} = 150.675 \] \[ Deviation_{6} = 72.62 \] \[ Timeout_{6} = 150.675 + 4 \cdot 72.62 = 460.155 \] Finally: \[ EstimatedRTT_{7} = 158.34 \] \[ Deviation_{7} = 74.565 \] \[ Timeout_{7} = 158.34 + 4 \cdot 74.565 = 456.6 \] \[ EstimatedRTT_{8} = 165.2975 \] \[ Deviation_{8} = 75.17 \] \[ Timeout_{8} = 165.2975 + 4 \cdot 75.17 = 366.98 \] \[ EstimatedRTT_{9} = 171.635 \] \[ Deviation_{9} = 74.515 \] \[ Timeout_{9} = 171.635 + 4 \cdot 74.515 = 453.69 \] ... Continue calculating until: \[ EstimatedRTT_{n} = 258 \cdot \Delta T \] \[ Deviation_{n} = \] Thus the Timeout will finally drop below 200 in approximately iterations.

Key Concepts

These are the key concepts you need to understand to accurately answer the question.

EstimatedRTT
In TCP's adaptive retransmission mechanism, the term **EstimatedRTT** is crucial. It represents the weighted average of measured Round Trip Times (RTTs) for data packets. This average helps predict the time it usually takes for a packet to travel from the source to the destination and back, which is essential for setting accurate timeouts.

We calculate **EstimatedRTT** using the formula:

\[ EstimatedRTT_{new} = (1 - \delta) \cdot EstimatedRTT_{old} + \delta \cdot SampleRTT \]

Here, \delta\ is a smoothing factor (commonly set to 1/8), **EstimatedRTT_{old}** is the previous estimated RTT, and **SampleRTT** is the newly measured RTT. By blending these values, the algorithm adapts to changing network conditions while filtering out short-term variations. This dynamic nature is crucial for maintaining efficient communication.
Deviation
Deviation measures the variability or the changeability of the RTT. Unlike **EstimatedRTT**, which focuses on the average, **Deviation** focuses on how much the RTT can vary around this average. Higher deviation indicates more variability and instability in the network.

The deviation is updated using the formula:

\[ Deviation_{new} = (1 - \delta) \cdot Deviation_{old} + \delta \cdot |SampleRTT - EstimatedRTT_{old}| \]

Here, the absolute difference between **SampleRTT** and **EstimatedRTT_{old}** is calculated to capture the RTT changes. Incorporating this difference ensures that the time-out calculation can adapt to sudden variations in the network and make judicious retransmission decisions.
Jacobson/Karels Algorithm
The **Jacobson/Karels algorithm** is a significant enhancement in the TCP protocol's timeout calculation. It ensures that TCP adapts better to the inconsistencies in network communication. By incorporating both **EstimatedRTT** and **Deviation**, the algorithm computes a timeout interval that adjusts according to the network's conditions.

The timeout calculation is based on this formula:

\[ Timeout = EstimatedRTT + 4 \cdot Deviation \]

This algorithm aims to predict the optimal timeout period. The factor of 4 in the formula ensures the timeout is conservatively ample to accommodate larger variations in RTT while preventing too frequent retransmissions that could congest the network. This balance reduces both delay and unnecessary retransmissions, enhancing overall network efficiency.
Timeout Calculation
**Timeout calculation** is a critical part of ensuring data packets are correctly received without overwhelming the network with too many retransmissions. It uses **EstimatedRTT** and **Deviation** to determine a time period after which, if an acknowledgment is not received, the packet is presumed lost, and a retransmission is triggered.

From our formula:

\[ Timeout = EstimatedRTT + 4 \cdot Deviation \]

We can see that the timeout dynamically adjusts by incorporating both average RTT (to account for typical network behavior) and its variability (to handle sudden delays or changes). If **EstimatedRTT** is 101.25 ms and **Deviation** is 40.625 ms, then the calculated **Timeout** would be:

\[ 101.25 + 4 \cdot 40.625 = 263.75 ms \]

This adaptability helps maintain a smooth, efficient flow of data across networks.
RTT Measurement
**RTT measurement** is the process of determining the time a data packet takes to travel from the sender to the receiver and back. This measurement is essential for adapting the TCP protocol to current network conditions.

The steps of measuring RTT are:
  • Send a data packet and start a timer.
  • Receive the acknowledgment for that packet.
  • Stop the timer.
  • Calculate the RTT as the difference between when the packet was sent and when the acknowledgment was received.
In TCP, **SampleRTT** combines with previous RTT values to form a smoother and more accurate measure—**EstimatedRTT**. By continually adjusting these measurements, TCP maintains efficient and reliable communication, adjusting for network variations on the fly.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

The sequence number field in the TCP header is 32 bits long, which is big enough to cover over 4 billion bytes of data. Even if this many bytes were never transferred over a single connection, why might the sequence number still wrap around from \(2^{32}-1\) to 0 ?

Diagnostic programs are commonly available that record the first 100 bytes, say, of every TCP connection to a certain (host, port). Outline what must be done with each received TCP packet, P, in order to determine if it contains data that belongs to the first 100 bytes of a connection to host HOST, port PORT. Assume the IP header is P.IPHEAD, the TCP header is P.TCPHEAD, and header fields are as named in Figures \(4.3\) and 5.4. Hint: To get initial sequence numbers (ISNs) you will have to examine every packet with the SYN bit set. Ignore the fact that sequence numbers will eventually be reused.

Suppose that, when a TCP segment is sent more than once, we take SampleRTT to be the time between the original transmission and the ACK, as in Figure \(5.10(\mathrm{a}) .\) Show that if a connection with a 1-packet window loses every other packet (i.e., each packet is transmitted twice), then EstimatedRTT increases to infinity. Assume TimeOut = EstimatedRTT; both algorithms presented in the text always set TimeOut even larger. Hint: EstimatedRTT \(=\) EstimatedRTT \(+\beta \times(\) SampleRT \(-\) EstimatedRTT).

Read the man page (or Windows equivalent) for the Unix/Windows utility netstat. Use netstat to see the state of the local TCP connections. Find out how long closing connections spend in TIME_WAIT.

Suppose we were to implement remote file system mounting using an unreliable RPC protocol that offers zero-or-more semantics. If a message reply is received, this improves to at-least-once semantics. We define read() to return the specified Nth block, rather than the next block in sequence; this way reading once is the same as reading twice and at-least-once semantics is thus the same as exactly once. (a) For what other file system operations is there no difference between at- leastonce and exactly once semantics? Consider open, create, write, seek, opendir, readdir, mkdir, delete (aka unlink), and rmdir. (b) For the remaining operations, which can have their semantics altered to achieve equivalence of at-least-once and exactly once? What file system operations are irreconcilable with at-least-once semantics? (c) Suppose the semantics of the rmdir system call are now that the given directory is removed if it exists, and nothing is done otherwise. How could you write a program to delete directories that distinguishes between these two cases?

See all solutions

Recommended explanations on Computer Science Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free