<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML><HEAD>
<META http-equiv=Content-Type content="text/html; charset=windows-1252">
<META content="MSHTML 6.00.2800.1264" name=GENERATOR>
<STYLE></STYLE>
</HEAD>
<BODY bgColor=#ffffff>
<DIV><FONT size=2>Lee,</FONT></DIV>
<DIV><FONT size=2></FONT> </DIV>
<DIV><FONT size=2>In light of "handoff" scenarios for wireless can the RTT be
calculated as the average within the transmission window ONLY? It
seems to me that this small consideration would also work well in a wireless
handoff scenario where several packets will be dropped within a single
transmission window (i.e. very close together). At this point the sudden
drop in RTT could then be easily detected and NOT trigger the throttling
mechanism for this special case. This would minimize bandwidth loss in
wireless scenarios while still maintaining the same optimization for wired
situations.</FONT></DIV>
<DIV><FONT size=2></FONT> </DIV>
<DIV><FONT size=2>pete</FONT></DIV>
<DIV><FONT size=2></FONT><!--StartFragment --></DIV>
<DIV><FONT size=2></FONT> </DIV>
<DIV><FONT size=2></FONT> </DIV>
<DIV><FONT size=2></FONT> </DIV>
<DIV> <FONT size=2>Lee Salzman wrote:</FONT></DIV><PRE>The funny thing is, ENet doesn't even use packet loss as an indicator of
changing network conditions just because it doesn't happen often enough
to really gauge what's going on. ENet instead uses changes in RTT of
reliable packets/pings to tweak the throttle.
Also, ENet can batch all protocol commands into a single UDP packet,
including acknowledgements. I imagine thsi should be helpful for
minimizing the amount of cross-talk.
Other than that I just want to gut the throttling code entirely based on
a scheme I outlined in an earlier post to the list, can't think of any
suggestions. :)
Lee
On Thu, May 06, 2004 at 12:35:37PM +1000, Pete Diemert wrote:
><I>
</I>><I> Hello,
</I>><I>
</I>><I> This is not so much an explicit question but rather a open query to elicit some useful insight into ENet. Understanding that ENet was originally designed as a protocol layer for sending video game data (i.e. bursty, lossy, low latency) we have actually found that the same library works well for our scenario which is entirely different, database synchronization over LAN and wireless networks (GPRS, GSM, 802.11, etc..). We decided to use ENet primarily for two reasons:
</I>><I>
</I>><I> 1) high scalability - we may want to have many (e.g. >1000) clients synchronizing with our server simultaneously.
</I>><I> 2) UDP protocol support - we need the option of fine tuning packet transmission to a much greater extent than is available using TCP socket options.
</I>><I>
</I>><I> The reasoning behind #1 is obvious but the requirements for #2 came about mostly due to some research into the dynamics of wireless networks. The key differentiators of wireless networks seem to be a) packet traffic is MUCH more expensive (both literally and figuratively) and b) packet loss in many cases is NOT due to congestion but rather due to known wireless network artefacts such as "handoff" (cell switch, momentary connection drop) and high bit error rate (BER). So, obviously, TCP connections can cause major headaches over wireless connections due to both the "chatty" nature of the protocol and the standard (Reno) re-transmit algorithm which ASSUMES network congestion on packet loss thereby immediately cutting bandwidth to resolve the issue rather than selectively retransmitting based on the actual cause of the packet loss (techniques floating around like SACK, SNOOP, protocols based partly on Explicit Loss Notification (ELN)).
</I>><I>
</I>><I> Which brings me back to ENet and my questions:
</I>><I>
</I>><I> - What are some techniques we can use to reduce packet traffic over ENet when a connection is not actively transmitting but will not impede maximum bandwidth use while streaming (i.e. simply increasing timeout may help the former but not help the latter and even the "average" transmit time may need to be quickly increased to maximize efficiency)?
</I>><I>
</I>><I> - Without a loss notification system at the router to know whether a lost packet was due to congestion are there some other techniques which can improve throughput over ENet when packet loss is due to a momentary drop in connection? (perhaps just a flag on the connection itself stating "I am a wireless connection, please don't use the standard throttling mechanism for packet loss when several drops occur in the same transmission window")
</I>><I>
</I>><I> Any insights or comments are greatly appreciated,
</I>><I> Pete Diemert</I></PRE>
<DIV><FONT size=2></FONT> </DIV></BODY></HTML>