[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r18931: {torctl} Add another ratio set to the stats output for speedracer. (torctl/trunk/python/TorCtl)
Author: mikeperry
Date: 2009-03-12 02:15:06 -0400 (Thu, 12 Mar 2009)
New Revision: 18931
Modified:
torctl/trunk/python/TorCtl/StatsSupport.py
Log:
Add another ratio set to the stats output for speedracer.
Modified: torctl/trunk/python/TorCtl/StatsSupport.py
===================================================================
--- torctl/trunk/python/TorCtl/StatsSupport.py 2009-03-12 05:08:56 UTC (rev 18930)
+++ torctl/trunk/python/TorCtl/StatsSupport.py 2009-03-12 06:15:06 UTC (rev 18931)
@@ -243,6 +243,13 @@
if bw == 0.0: return 0
else: return self.bw/(1024.*bw)
+ def strm_ratio(self):
+ """Return the ratio of the Router's stream capacity to the average
+ stream capacity passed in as 'mean'"""
+ bw = self.bwstats.mean
+ if StatsRouter.global_mean == 0.0: return 0
+ else: return (1.0*bw)/StatsRouter.global_mean
+
def current_uptime(self):
if self.became_active_at:
ret = (self.total_active_uptime+(time.time()-self.became_active_at))
@@ -277,13 +284,15 @@
return (3600.*(self.circ_succeeded+self.strm_succeeded))/self.current_uptime()
key = """Metatroller Statistics:
- CC=Circuits Chosen CF=Circuits Failed CS=Circuit Suspected
- SC=Streams Chosen SF=Streams Failed SS=Streams Suspected
- FH=Failed per Hour SH=Suspected per Hour ET=avg circuit Extend Time (s)
- EB=mean BW (K) BD=BW std Dev (K) BR=Ratio of observed to avg BW
- ZB=BW z-test value PB=Probability(z-bw) ZR=Ratio z-test value
- PR=Prob(z-ratio) U=Uptime (h)\n"""
+ CC=Circuits Chosen CF=Circuits Failed CS=Circuit Suspected
+ SC=Streams Chosen SF=Streams Failed SS=Streams Suspected
+ FH=Failed per Hour SH=Suspected per Hour ET=avg circuit Extend Time (s)
+ EB=mean BW (K) BD=BW std Dev (K) BR=Ratio of observed to avg BW
+ ZB=BW z-test value PB=Probability(z-bw) ZR=Ratio z-test value
+ PR=Prob(z-ratio) SR=Global mean/mean BW U=Uptime (h)\n"""
+ global_mean = 0.0
+
def __str__(self):
return (self.idhex+" ("+self.nickname+")\n"
+" CC="+str(self.circ_chosen)
@@ -302,6 +311,7 @@
+" BR="+str(round(self.bw_ratio(),1))
+" ZR="+str(round(self.z_ratio,1))
+" PR="+(str(round(self.prob_zr,3))[1:])
+ +" SR="+(str(round(self.strm_ratio(),1)))
+" U="+str(round(self.current_uptime()/3600, 1))+"\n")
def sanity_check(self):
@@ -431,6 +441,8 @@
(avg, dev) = self.run_zrtest()
f.write("BW ratio stats: u="+str(round(avg,1))+" s="+str(round(dev,1))+"\n")
+ StatsRouter.global_mean = avg
+
# Circ, strm infoz
f.write("Circ failure ratio: "+str(self.circ_failed)
+"/"+str(self.circ_count)+"\n")
@@ -453,6 +465,11 @@
bw_rate.sort(lambda x, y: cmp(y.bw_ratio(), x.bw_ratio()))
self.write_routers(f, bw_rate, "Bandwidth Ratios")
+ # sort+print by bandwidth
+ strm_ratio = copy.copy(self.sorted_r)
+ strm_ratio.sort(lambda x, y: cmp(x.strm_ratio(), y.strm_ratio()))
+ self.write_routers(f, strm_ratio, "Stream Ratios")
+
failed = copy.copy(self.sorted_r)
failed.sort(lambda x, y:
cmp(y.circ_failed+y.strm_failed,