File: sim.py

package info (click to toggle)
tinyos 2.1.2%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: buster, jessie, jessie-kfreebsd, stretch
  • size: 47,476 kB
  • ctags: 36,607
  • sloc: ansic: 63,646; cpp: 14,974; java: 10,358; python: 5,215; makefile: 1,724; sh: 902; asm: 597; xml: 392; perl: 74; awk: 46
file content (34 lines) | stat: -rw-r--r-- 799 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
import TOSSIM
import sys

t = TOSSIM.Tossim([])
m = t.mac()
r = t.radio()
t.init()

t.addChannel("TestSrpP", sys.stdout)
#t.addChannel("SourceRouteEngineP", sys.stdout)
#t.addChannel("SRPDebug", sys.stdout)
#t.addChannel("SRPInfo", sys.stdout)
t.addChannel("SRPError", sys.stdout)

f = open("topo.txt", "r")
lines = f.readlines()

edges = {}

for [src, dest, gain] in [line.split()[1:] for line in lines if line.startswith("gain")]:
    src = int(src)
    dest = int(dest)
    r.add(src, dest, float(gain))
    edges[src] = edges.get(src, [])+[dest]

for nodeId in edges:
    n = t.getNode(nodeId)
    for i in range(100):
        n.addNoiseTraceReading(-105)
    n.createNoiseModel()
    n.bootAtTime(t.ticksPerSecond()/4 * nodeId )

while t.time() / t.ticksPerSecond() < 300:
    t.runNextEvent()