• R/O
  • SSH

Tags
No Tags

Frequently used words (click to add to your profile)

javac++androidlinuxc#windowsobjective-ccocoa誰得qtpythonphprubygameguibathyscaphec計画中(planning stage)翻訳omegatframeworktwitterdomtestvb.netdirectxゲームエンジンbtronarduinopreviewer

File Info

Rev. e788865417c80884c49f3e4f6dd112ef431dcf89
Size 2,997 bytes
Time 2009-09-22 18:13:25
Author lorenzo
Log Message

I simply removed some unnecessary comments from the code and set the time
slice duration to 20 sec.

Content

#!/usr/bin/env python
# dump unique contacts to stdout

import sys
from sociopatterns import Contact, Sighting
from sociopatterns.loader import Loader
import string

class PowerAnalyzer:
    def __init__(self, loader, time_delta=60, tag_id_min=None, tag_id_max=None, filter=None):
        self.loader = iter(loader)

        #self.ip={}
        
        self.filter = filter
        self.time_delta = time_delta
        self.tnext = -1

        self.tag_id_min = tag_id_min
        self.tag_id_max = tag_id_max

        self.count_clear()

    def count_clear(self):
	self.count = {}
        self.boot_count = {}
        self.ip_dict={}
        #self.ip_dict_ext={}
        

    def count_get(self):
        frame = {}

        frame['time'] = self.tnext
        frame['count'] = dict(self.count)
        frame['boot_count'] = dict(self.boot_count)
        frame["antenna"]=dict(self.ip_dict)

        #frame["antenna_ext"]=dict(self.ip_dict_ext)


        return frame

    def __iter__(self):
        for obj in self.loader:
            #print obj.ip
            if self.tnext < 0:
                self.tnext = obj.t + self.time_delta

            while obj.t >= self.tnext:
                yield self.count_get()
                self.count_clear()
                self.tnext += self.time_delta

            if self.filter and self.filter(obj):
                continue

	    if self.tag_id_min and obj.id < self.tag_id_min:
                continue

	    if self.tag_id_max and obj.id >= self.tag_id_max:
                continue

            if not obj.id in self.count:
                self.count[obj.id] = {0:0, 1:0, 2:0, 3:0}
                self.boot_count[obj.id] = set()
                self.ip_dict[obj.id] = set()
                #self.ip_dict_ext[obj.id] = set()

                
            if obj.protocol == Contact.protocol:
                self.count[obj.id][3] += 1
            elif obj.protocol == Sighting.protocol:
                self.count[obj.id][obj.strength] += 1
		self.boot_count[obj.id].add(obj.boot_count)
		self.ip_dict[obj.id].add(obj.ip)

                #print "self.ip_dict is, ", self.ip_dict
                #self.ip_dict_ext[obj.id].add(obj.ip)
                

                #print "the station ip is, ", obj.ip


XXTEA_CRYPTO_KEY = ( 0xd2e3fd73, 0xfa70ca9c, 0xe2575826, 0x0fe09946 )

loader = Loader(sys.argv[1:], decode=1, xxtea_crypto_key=XXTEA_CRYPTO_KEY, load_contacts=1, unique_contacts=0, load_sightings=1, unique_sightings=0)

analyzer = PowerAnalyzer(loader, time_delta=20, tag_id_min=1100, tag_id_max=2047)



for frame in analyzer:
    for tag_id in frame['count']:
        if len(frame['boot_count'][tag_id]) < 1:
	    continue


        x=frame['antenna'][tag_id]

        print frame['time'], tag_id, frame['count'][tag_id][0],\
              frame['count'][tag_id][1],\
              frame['count'][tag_id][2], frame['count'][tag_id][3],\
              list(frame['boot_count'][tag_id])[0], string.join(map(str, x)) + " -1" * (7-len(x))