亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? statistics.cc

?? use swarm intelligence to simulate network routings in omnet
?? CC
字號:
// -*- C++ -*-
// Copyright (C) 2003 Leherstuh f黵 Betrieb System/ Verteilte System, 
// Universitaet Dortmund 
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.

// Author: Muddassar Farooq
// Informatik III, Universitaet Dortmund
// Germany

//-------------------------------------------------------------
// file: statisitics.h -- A Singleton Class for Global Statisitics
//        (part of AntNet Routing Simulation)
//-------------------------------------------------------------

#include "statistics.h"

Define_Module( statistics );

statistics::statistics(const char *name, cModule *parentmodule,	unsigned stacksize)
	:cSimpleModule(name, parentmodule, stacksize)
{
	totalBitsGenerated = 0;
	totalBitsDelivered = 0;
	totalBitsLost = 0;

	totalAntsGenerated = 0;
	totalAntsDelivered = 0;
	totalAntsDeleted = 0;
	queueDelay = 0;
	qEntries = 0;

	packetDelay = 0;
	pEntries = 0;
	i = 0;
	packetsInQueue = 0;
	hops = 0;
	hEntries = 0;
	antHops = 0;
	aEntries = 0;
	totalBitsUnDelivered = 0;
	bitsGenerated = 0;
	bitsDelivered = 0;
	totalAntsBitsOnNetwork = 0;
	entriesInRoutingTable = 0;
	totalBandWidth = 0;
	totalDownBitsGenerated = 0;

	dEntries = 0;
	antsProcessed = 0;

	eHopsEntries = 0;
}

statistics::~statistics()
{
	map<int,pair<double,double>*>::const_iterator J;

	for(J = tPutMap.begin(); J != tPutMap.end(); J++)
	{
		delete (*J).second;
	}
}

void statistics::initialize()
{
	strcpy(sFileName,par("statFile"));
	numStations = par("numStations");
}

void statistics::incrAntsProcessed()
{
	antsProcessed++;
}

void statistics::incrEntriesInRoutingTable(int entries)
{
	entriesInRoutingTable += static_cast<double> (entries);
}

void statistics::incrTotalBandWidthInNetwork(double bandwidth)
{
	totalBandWidth += bandwidth;
}

void statistics::incrTotalAntBits(double size)
{
	totalAntsBitsOnNetwork += size;
}

void statistics::incrNumHops(int nHops)
{
	hops += nHops;
	hEntries++;
}

void statistics::incrTotalDownBitsGenerated()
{
	totalDownBitsGenerated++;
}

void statistics::incrBitsGenerated(double bits)
{
	bitsGenerated += bits;
}

void statistics::incrBitsDelivered(double bits)
{
	bitsDelivered += bits;
}


void statistics::incrAntHops(int aHops)
{
	antHops += aHops;
	aEntries++;
}

void statistics::incrTotalBitsGenerated()
{
	totalBitsGenerated++;
}

void statistics::incrTotalBitsDelivered()
{
	totalBitsDelivered++;
}

void statistics:: incrTotalBitsLost()
{
	totalBitsLost++;
}

void statistics::incrTotalBitsUndeliverable()
{
	totalBitsUnDelivered++;
}


void statistics:: incrTotalAntsGenerated()
{
	totalAntsGenerated++;
}

void statistics:: incrTotalAntsReceived()
{
	totalAntsDelivered++;
}

void statistics:: incrTotalAntsDeleted()
{
	totalAntsDeleted++;
}

void statistics:: insertQueueDelay(double qDelay)
{
	queueDelay+= qDelay,
	qEntries++;
}

void statistics::insertPacketDelay(double delay)
{
	pDelay.collect(delay);

	packetDelay += delay;
	pEntries++;
}

void statistics::insertAntLife(double lValue)
{
	antLife.collect(lValue);
}

void statistics::incrPacketInQueue(double lPacket)
{
	packetsInQueue += lPacket;
}


void statistics::insertThroughPutPacketDelay(double tPut, double tDelay, int time)
{
	map<int,pair<double,double>*>::iterator I = tPutMap.find(time);
	if( I != tPutMap.end() )
	{
		pair<double,double> &thePair = *((*I).second);
		thePair.first += tPut;
		thePair.second += tDelay;
	}
	else
	{
		pair<double,double> *p = new pair<double,double>(tPut,tDelay);
		tPutMap[time] = p;
	}

	simTime = time;

}

void statistics::calculateThroughPutPacketDelay(int time)
{
	double totalThroughPut = 0.0;
	int i = 0;
}

double statistics::ninteythPercentile(cStdDev tVal)
{

	double mean = tVal.mean();
	double stdDev = tVal.stddev();
	double z = 1.29;

	double value = mean + z * stdDev;
	return value;
}

void statistics::showStatistics()
{
	totalAntsBitsOnNetwork = totalAntsBitsOnNetwork/simTime;

	sFile = fopen(sFileName,"w+");

	fprintf(sFile, "SimTime:  %d\n", simTime);
	fprintf(sFile, "PGenerated::  %.3f\n", totalBitsGenerated); 
	fprintf(sFile, "PDelivered:  %.3f\n",totalBitsDelivered);
	fprintf(sFile, "PDropped:  %.3f\n",totalBitsLost);
	fprintf(sFile, "PUndeliverable:  %.3f\n",totalBitsUnDelivered);
	fprintf(sFile, "PQueue:  %.3f\n",packetsInQueue);
	fprintf(sFile, "PercentDelivered:  %.3f\n",(totalBitsDelivered/(totalBitsGenerated-totalBitsUnDelivered-totalDownBitsGenerated)*100.0));
	fprintf(sFile, "AGenerated:  %.3f\n", totalAntsGenerated); 
	fprintf(sFile, "AReceived:  %.3f\n",totalAntsDelivered);
	fprintf(sFile, "ADropped:  %.3f\n",totalAntsDeleted);
	fprintf(sFile, "AHop:  %.3f\n", (float) antHops/aEntries);
	fprintf(sFile, "ALife:  %.3f\n", (float) antLife.mean());
	fprintf(sFile, "AProcessed:  %.3f\n", (float) antsProcessed);
	fprintf(sFile, "AntsBits:  %.3f\n", (float) totalAntsBitsOnNetwork);
	fprintf(sFile, "TotalBandWidth:  %.3f\n", (float) totalBandWidth);
	fprintf(sFile, "ControlOverhead:  %.3f\n", (float) totalAntsBitsOnNetwork/totalBandWidth*100.0);
	double aLife = ninteythPercentile(antLife);
	fprintf(sFile, "A90Life:  %.3f\n", aLife);
	fprintf(sFile, "PQueueDelay:  %.3f\n",queueDelay/qEntries);
	fprintf(sFile, "PacketDelay:  %.3f\n",packetDelay/pEntries);
	double ninteyDelay = ninteythPercentile(pDelay);
	fprintf(sFile, "90PacketDelay:  %.3f\n",ninteyDelay);
	fprintf(sFile, "ThroughPut:  %.3f\n", bitsDelivered/(simTime*1000000));
	double fHops = (float) hops /hEntries;
	fprintf(sFile, "PHops:  %.3f\n", fHops);
	fprintf(sFile, "EntriesRT:  %.3f\n", entriesInRoutingTable/numStations);

	calculateThroughPutPacketDelay(simTime);
	for(int k = 0; k < simTime; k++)
	{
		fprintf(sFile,"%d %.2f\n",k,(*tPutMap[k]).first);
	}

	for(int l = 0; l < simTime; l++)
	{
		fprintf(sFile,"%d %.4f\n",l,((*tPutMap[l]).second)/numStations);
	}
	
	fclose(sFile);
}

void statistics::finish()
{
	ev<<"Module" << fullPath() << endl;
	showStatistics();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
不卡的av网站| 99久久久国产精品免费蜜臀| 亚洲另类中文字| 中文字幕免费不卡在线| 久久五月婷婷丁香社区| 2021久久国产精品不只是精品| 日韩欧美在线网站| 日韩欧美中文字幕精品| 91精品在线观看入口| 5858s免费视频成人| 日韩一区二区三免费高清| 91精品欧美久久久久久动漫 | 久久精品亚洲精品国产欧美| 欧美电影免费观看高清完整版| 日韩免费观看高清完整版在线观看| 91精品中文字幕一区二区三区| 日韩美女视频在线| 国产午夜精品久久| 亚洲视频小说图片| 午夜影院久久久| 精品在线播放免费| 不卡区在线中文字幕| 在线视频国内一区二区| 宅男噜噜噜66一区二区66| 久久九九影视网| 一区二区成人在线| 蜜桃视频一区二区三区| 丁香亚洲综合激情啪啪综合| 99久久精品免费精品国产| 欧美日韩国产精品成人| 国产亚洲一区二区三区在线观看| 亚洲日本中文字幕区| 男男gaygay亚洲| 91麻豆精东视频| 日韩欧美在线不卡| 亚洲卡通动漫在线| 精品一二三四在线| 在线观看日韩国产| 国产丝袜在线精品| 日韩福利电影在线| 一本一道综合狠狠老| 欧美r级在线观看| 一区二区久久久久久| 国产成人夜色高潮福利影视| 欧美日本一道本在线视频| 国产蜜臀97一区二区三区| 午夜视频一区二区| 91同城在线观看| 久久综合久久综合九色| 夜夜嗨av一区二区三区| 国产成人精品www牛牛影视| 欧美日韩国产色站一区二区三区| 中文无字幕一区二区三区 | 91麻豆精品国产自产在线 | 久久综合久久99| 一片黄亚洲嫩模| 成人av电影免费观看| 精品国产三级电影在线观看| 三级欧美韩日大片在线看| 99精品视频在线免费观看| 久久久久久久久99精品| 美女尤物国产一区| 911国产精品| 午夜精品成人在线视频| 91国偷自产一区二区使用方法| 国产网站一区二区| 日本午夜精品一区二区三区电影 | 一区二区三区四区高清精品免费观看 | 亚洲五码中文字幕| 国产不卡在线一区| 久久女同互慰一区二区三区| 免费成人你懂的| 91精品久久久久久久99蜜桃| 亚洲成年人网站在线观看| 欧美视频一区二区三区四区| 一区二区三区欧美在线观看| 91麻豆免费在线观看| 亚洲日本成人在线观看| 99精品视频在线观看免费| 自拍偷拍国产精品| 欧美在线不卡一区| 亚洲国产va精品久久久不卡综合| 欧美性色黄大片| 日韩综合小视频| 日韩免费电影网站| 国产麻豆视频一区| 国产精品视频免费| 91网站在线观看视频| 亚洲一区二区三区美女| 欧美日韩久久不卡| 久久99精品国产麻豆婷婷| 久久嫩草精品久久久精品| 成人永久aaa| 亚洲视频1区2区| 777亚洲妇女| 国产一区二区三区电影在线观看 | 欧美视频完全免费看| 性感美女极品91精品| 日韩免费电影网站| 成人免费va视频| 亚洲成人精品一区二区| 精品日韩成人av| 成人av免费在线观看| 亚洲123区在线观看| 亚洲精品在线三区| aaa国产一区| 欧美aa在线视频| 国产拍揄自揄精品视频麻豆| 一本色道综合亚洲| 精油按摩中文字幕久久| 亚洲色图视频网站| 欧美电视剧免费观看| 色综合天天综合网国产成人综合天| 亚洲二区在线观看| 国产日韩精品一区| 欧美日韩激情一区二区三区| 国产福利精品导航| 亚洲国产综合91精品麻豆| 国产色一区二区| 欧美另类一区二区三区| www.色综合.com| 久久99国产精品久久99| 夜夜操天天操亚洲| 国产亚洲福利社区一区| 欧美高清视频www夜色资源网| 国产·精品毛片| 免费久久精品视频| 亚洲一区二区三区中文字幕在线| 国产视频在线观看一区二区三区 | 国产欧美日韩视频一区二区| 欧美日韩国产一二三| 91丨九色porny丨蝌蚪| 国产麻豆精品视频| 青青草精品视频| 亚洲国产视频在线| 亚洲精品v日韩精品| 中文字幕av一区二区三区免费看 | 国产精品视频观看| 26uuu亚洲综合色| 欧美一区二区三区在线观看 | 粉嫩久久99精品久久久久久夜| 午夜免费久久看| 一区二区三区高清不卡| 国产精品国产自产拍高清av| 国产亚洲综合在线| 久久精品欧美日韩| 国产网站一区二区| 国产亚洲人成网站| 久久久精品国产免费观看同学| 欧美一区二区三区在| 欧美性受xxxx| 欧美日韩国产免费| 91精品久久久久久久91蜜桃 | 成熟亚洲日本毛茸茸凸凹| 美女国产一区二区三区| 免费观看30秒视频久久| 蜜桃久久久久久| 狠狠色狠狠色合久久伊人| 狠狠色狠狠色合久久伊人| 国产精品538一区二区在线| 久久国产尿小便嘘嘘| 国产麻豆成人传媒免费观看| 国模一区二区三区白浆| 国产乱码一区二区三区| 成人午夜视频免费看| 成人激情图片网| 99国产精品一区| 欧美日韩国产高清一区| 欧美一级午夜免费电影| 日韩免费看的电影| 国产精品丝袜黑色高跟| 亚洲美女少妇撒尿| 日韩有码一区二区三区| 美国毛片一区二区| 成人免费视频免费观看| 色偷偷久久一区二区三区| 欧美日韩国产电影| 亚洲精品一区二区三区福利| 国产精品免费免费| 一级女性全黄久久生活片免费| 天天色 色综合| 国产中文字幕一区| 一本久久综合亚洲鲁鲁五月天| 欧美精品三级在线观看| 久久久久国产精品厨房| 亚洲激情中文1区| 精品在线一区二区三区| 97精品电影院| 欧美一区二区福利视频| 国产精品色在线| 免费在线看一区| 99久久婷婷国产| 精品乱人伦一区二区三区| 中文字幕中文字幕一区二区| 日韩制服丝袜av| 91最新地址在线播放| 日韩欧美精品三级| 亚洲免费观看视频| 国产在线精品免费av| 精品视频全国免费看|