expavg-est.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/expavg-est.cc,v 1.4 2005/08/26 05:05:27 tomh Exp $";
00044 #endif
00045 
00046 
00047 #include <math.h>
00048 #include "estimator.h"
00049 
00050 class ExpAvg_Est : public Estimator {
00051 public:
00052     ExpAvg_Est() {bind("w_",&w_);};
00053 protected:
00054     void estimate();
00055     double w_;
00056 };
00057 
00058 
00059 void ExpAvg_Est::estimate()
00060 {
00061     avload_=(1-w_)*avload_+w_*meas_mod_->bitcnt()/period_;
00062     //printf("%f %f %f\n",Scheduler::instance().clock(),avload_,meas_mod_->bitcnt()/period_);
00063     fflush(stdout);
00064     meas_mod_->resetbitcnt(); 
00065 }
00066 
00067 static class ExpAvg_EstClass : public TclClass {
00068 public:
00069     ExpAvg_EstClass() : TclClass ("Est/ExpAvg") {}
00070     TclObject* create(int,const char*const*) {
00071         return (new ExpAvg_Est());
00072     }
00073 }class_expavg_est;
00074 

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