00001 00002 /* 00003 * hdr_qs.cc 00004 * Copyright (C) 2001 by the University of Southern California 00005 * $Id: hdr_qs.cc,v 1.4 2005/08/25 18:58:10 johnh Exp $ 00006 * 00007 * This program is free software; you can redistribute it and/or 00008 * modify it under the terms of the GNU General Public License, 00009 * version 2, as published by the Free Software Foundation. 00010 * 00011 * This program is distributed in the hope that it will be useful, 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 * GNU General Public License for more details. 00015 * 00016 * You should have received a copy of the GNU General Public License along 00017 * with this program; if not, write to the Free Software Foundation, Inc., 00018 * 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA. 00019 * 00020 * 00021 * The copyright of this module includes the following 00022 * linking-with-specific-other-licenses addition: 00023 * 00024 * In addition, as a special exception, the copyright holders of 00025 * this module give you permission to combine (via static or 00026 * dynamic linking) this module with free software programs or 00027 * libraries that are released under the GNU LGPL and with code 00028 * included in the standard release of ns-2 under the Apache 2.0 00029 * license or under otherwise-compatible licenses with advertising 00030 * requirements (or modified versions of such code, with unchanged 00031 * license). You may copy and distribute such a system following the 00032 * terms of the GNU GPL for this module and the licenses of the 00033 * other code concerned, provided that you include the source code of 00034 * that other code when and as the GNU GPL requires distribution of 00035 * source code. 00036 * 00037 * Note that people who make modified versions of this module 00038 * are not obligated to grant this special exception for their 00039 * modified versions; it is their choice whether to do so. The GNU 00040 * General Public License gives permission to release a modified 00041 * version without this exception; this exception also makes it 00042 * possible to release a modified version which carries forward this 00043 * exception. 00044 * 00045 */ 00046 00047 /* 00048 * Quick Start for TCP and IP. 00049 * A scheme for transport protocols to dynamically determine initial 00050 * congestion window size. 00051 * 00052 * http://www.ietf.org/internet-drafts/draft-amit-quick-start-02.ps 00053 * 00054 * Packet header definition for Quick Start implementation 00055 * hdr_qs.h 00056 * 00057 * Srikanth Sundarrajan, 2002 00058 * sundarra@usc.edu 00059 */ 00060 00061 #include <stdio.h> 00062 #include "hdr_qs.h" 00063 #include "qsagent.h" 00064 #include <math.h> 00065 00066 int hdr_qs::offset_; 00067 00068 static class QSHeaderClass : public PacketHeaderClass { 00069 public: 00070 QSHeaderClass() : PacketHeaderClass("PacketHeader/QS", sizeof(hdr_qs)) { 00071 bind_offset(&hdr_qs::offset_); 00072 } 00073 00074 } class_qshdr; 00075 00076 00077 /* 00078 * These two functions convert rate in QS packet to KBps and vice versa. 00079 */ 00080 double hdr_qs::rate_to_Bps(int rate) 00081 { 00082 if (rate == 0) 00083 return 0; 00084 switch(QSAgent::rate_function_) { 00085 case 1: 00086 default: 00087 return rate * 10240; // rate unit: 10 kilobytes per sec 00088 case 2: 00089 return pow(2, rate) * 5000; // exponential, base 2 00090 } 00091 } 00092 00093 int hdr_qs::Bps_to_rate(double Bps) 00094 { 00095 if (Bps == 0) 00096 return 0; 00097 switch(QSAgent::rate_function_) { 00098 case 1: 00099 default: 00100 return (int) Bps / 10240; // rate unit: 10 kilobytes per sec 00101 case 2: 00102 return (int) (log(Bps / 5000) / log(2)); 00103 } 00104 } 00105 00106 // Local Variables: 00107 // mode:c++ 00108 // c-basic-offset: 8 00109 // End: 00110
1.4.6