hb-adc.cc

Go to the documentation of this file.
00001 /* -*-  Mode:C++; c-basic-offset:8; tab-width:8; indent-tabs-mode:t -*- */
00002 /*
00003  * Copyright (c) Xerox Corporation 1997. All rights reserved.
00004  *
00005  * This program is free software; you can redistribute it and/or modify it
00006  * under the terms of the GNU General Public License as published by the
00007  * Free Software Foundation; either version 2 of the License, or (at your
00008  * option) any later version.
00009  *
00010  * This program is distributed in the hope that it will be useful, but
00011  * WITHOUT ANY WARRANTY; without even the implied warranty of
00012  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00013  * General Public License for more details.
00014  *
00015  * You should have received a copy of the GNU General Public License along
00016  * with this program; if not, write to the Free Software Foundation, Inc.,
00017  * 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
00018  *
00019  * Linking this file statically or dynamically with other modules is making
00020  * a combined work based on this file.  Thus, the terms and conditions of
00021  * the GNU General Public License cover the whole combination.
00022  *
00023  * In addition, as a special exception, the copyright holders of this file
00024  * give you permission to combine this file with free software programs or
00025  * libraries that are released under the GNU LGPL and with code included in
00026  * the standard release of ns-2 under the Apache 2.0 license or under
00027  * otherwise-compatible licenses with advertising requirements (or modified
00028  * versions of such code, with unchanged license).  You may copy and
00029  * distribute such a system following the terms of the GNU GPL for this
00030  * file and the licenses of the other code concerned, provided that you
00031  * include the source code of that other code when and as the GNU GPL
00032  * requires distribution of source code.
00033  *
00034  * Note that people who make modified versions of this file are not
00035  * obligated to grant this special exception for their modified versions;
00036  * it is their choice whether to do so.  The GNU General Public License
00037  * gives permission to release a modified version without this exception;
00038  * this exception also makes it possible to release a modified version
00039  * which carries forward this exception.
00040  */
00041 #ifndef lint
00042 static const char rcsid[] =
00043     "@(#) $Header: /nfs/jade/vint/CVSROOT/ns-2/adc/hb-adc.cc,v 1.6 2005/08/26 05:05:27 tomh Exp $";
00044 #endif
00045 
00046 //Hoeffding Bounds Admission Control
00047 
00048 #include "adc.h"
00049 #include <stdlib.h>
00050 #include <math.h>
00051 
00052 class HB_ADC : public ADC {
00053 public:
00054     HB_ADC();
00055     void teardown_action(int,double,int);
00056     void rej_action(int,double,int);
00057 protected:
00058     int admit_flow(int,double,int);
00059     int rejected_; 
00060     double epsilon_;
00061     double sump2_;
00062 };
00063 
00064 HB_ADC::HB_ADC() : rejected_(0), sump2_(0)
00065 {
00066     bind("epsilon_", &epsilon_);
00067     type_ = new char[3];
00068     strcpy(type_, "HB");
00069 }
00070 
00071 
00072 int HB_ADC::admit_flow(int cl,double r,int b)
00073 {
00074     //get peak rate this class of flow
00075     double p=peak_rate(cl,r,b);
00076     if (backoff_) {
00077         if (rejected_)
00078             return 0;
00079     }   
00080     //printf("Peak rate: %f Avload: %f Rem %f %f %f\n",p,est_[cl]->avload(),sqrt(log(1/epsilon_)*sump2_/2),log(1/epsilon_),sump2_);
00081     
00082     if ((p+est_[cl]->avload()+sqrt(log(1/epsilon_)*sump2_/2)) <= bandwidth_) {
00083         sump2_+= p*p;
00084         est_[cl]->change_avload(p);
00085         return 1;
00086     }
00087     else {
00088         rejected_=1;
00089         return 0;
00090     }
00091 }
00092 
00093 
00094 void HB_ADC::rej_action(int cl,double r,int b)
00095 {
00096     double p=peak_rate(cl,r,b);
00097     sump2_ -= p*p;
00098 }
00099 
00100 
00101 void HB_ADC::teardown_action(int cl,double r,int b)
00102 {
00103     rejected_=0;
00104     double p=peak_rate(cl,r,b);
00105     sump2_ -= p*p;
00106 }
00107 
00108 static class HB_ADCClass : public TclClass {
00109 public:
00110     HB_ADCClass() : TclClass("ADC/HB") {}
00111     TclObject* create(int,const char*const*) {
00112         return (new HB_ADC());
00113     }
00114 }class_hb_adc;

Generated on Tue Mar 6 16:47:45 2007 for ns2 Network Simulator 2.29 by  doxygen 1.4.6