 
 
 
 
 
 
   
Application-dependent proxy: An important aspect of interfacing with legacy applications is to use an application proxy that can signal an application's requirements to the OverQoS network. In the case of MPEG streaming, the application proxy interprets the packets in the stream and marks the priority of recovery for each packet. For smoothing losses, all packets in a stream are associated with the same priority. For obtaining bandwidth guarantees, the proxy needs to use a signaling mechanism like RSVP [10] to reserve the resources along an overlay path.
Choosing parameters: The parameters  ,
,  and
 and  need to be estimated for determining the sending rate
need to be estimated for determining the sending rate  . While
. While  can be estimated as the instantaneous number of flows, we set
can be estimated as the instantaneous number of flows, we set  as
the average number of flows observed over a larger period of time
(certain flows have a very short lifetime). This is to reduce the
variations in the sending rate induced by
 as
the average number of flows observed over a larger period of time
(certain flows have a very short lifetime). This is to reduce the
variations in the sending rate induced by  . Only flows that
generate a minimum number of packets, are used in calculating
. Only flows that
generate a minimum number of packets, are used in calculating  .  We
leverage the techniques used in equation based congestion
control [16] for estimating the
.  We
leverage the techniques used in equation based congestion
control [16] for estimating the  and
 and  between two
OverQoS nodes. We choose a reasonably low value of the target
loss-rate,
 between two
OverQoS nodes. We choose a reasonably low value of the target
loss-rate,  , for most of our experiments. For FEC+ARQ based
CLVLs, we choose the packet recovery time,
, for most of our experiments. For FEC+ARQ based
CLVLs, we choose the packet recovery time,  to be
 to be 
 .
.
Startup phase: During periods of no usage (i.e. when
 =0), we do not send additional traffic to estimate the virtual link
parameters. After such a phase, OverQoS nodes need
to determine an initial value of
=0), we do not send additional traffic to estimate the virtual link
parameters. After such a phase, OverQoS nodes need
to determine an initial value of  along a virtual link. Like TCP,
we use a slow-start phase to estimate the initial value of
 along a virtual link. Like TCP,
we use a slow-start phase to estimate the initial value of
 . During the slow-start phase, OverQoS does not use loss
recovery.
. During the slow-start phase, OverQoS does not use loss
recovery. 
FEC implementation: Our implementation can perform FEC encoding
and decoding (for a redundancy factor as high as 50%) at over  Mbps on a Pentium III 866 MHz running Linux 2.4.18 kernel.  Since we
operate on small window sizes, (
Mbps on a Pentium III 866 MHz running Linux 2.4.18 kernel.  Since we
operate on small window sizes, ( ), Reed Solomon coding is not a
bottleneck. For example, on a virtual link with an
), Reed Solomon coding is not a
bottleneck. For example, on a virtual link with an  ms, the
window size is bounded by
 ms, the
window size is bounded by  for sending rates less than
 for sending rates less than  Mbps. Other coding techniques like Tornado codes [23] while
faster, may not provide the same level of error correction for small
window sizes.
Mbps. Other coding techniques like Tornado codes [23] while
faster, may not provide the same level of error correction for small
window sizes.
 
 
 
 
