The DynamIc Trace Library is a Java library to efficiently handle and combine a variety of time-indexed event traces (e.g. position, contact, or message transfer traces), as well as store meta-data in a standardized way. Its core is very generic and can handle either stateless events (e.g., a received beacon), or stateful events (e.g., groups modified by join and leave events).
I am releasing the code as is under popular pressure for the plausible mobility and reachability code built on top of it. It is under active development but documentation is unfortunately still lacking at this point. However, rudimentary documentation is built into the CLI interface (see below).
The core and graphs module are being used in research projects by myself and others can be considered quite stable. The transfers module is currently serving as the basis for an opportunistic network simulator, but will probably see some changes and improvement as development of the simulator continues.
DITL is built around the following design choices:
-
Everything is a trace. Calculations and simulations all become transformations of one set of traces into another set of traces. For example, an opportunistic network simulator merely converts a edge trace to a message and a buffer trace.
-
Pre-calculate as much as possible. For example, edges arising from the proximity of two nodes (i.e., the disk-based radio model) should only be calculated once and not for every run of a simulation. Same goes for connected components, etc.
-
Everything should be replayable. By keeping traces of everything, is it easy to move back and forth in time to find and replay a particular sequence of events.
-
Do not reinvent the wheel. There are very good tools for mobility generation, statistics, and others. DITL just tries to import/export data in ways that interface with existing tools. For example, it can import/export data from NS or ONE. It also has rudimentary reporting functions which mostly dump raw distributions (we then use the R language for processing them).
A trace is a combination of three things:
- a time-indexed sequence of events
- (Optional) if the trace is stateful, a time-indexed sequence of state snapshots corresponding to the events
- its associated meta-data
All traces have the following meta-data: name, description, type, min/max time, min/max update interval (the time between successive events), snapshot interval (stateful traces only), priority, and time unit (how many time units to a second). This is easily extensible and some traces contain more meta-data. For example, movement traces also save min/max X and Y coordinates.
Here is a list of the trace types currently in the library:
- Graphs module
- presence
- arc
- edge
- movement
- beacon (stateless)
- group
- Transfers module
- message
- buffer
- transfer
- Plausibile module
- windowed edge
A store is a collection of traces. It is intended to be used as a container for several traces relating to the same source of events. For example, a store could be used to contain a simulated Random Waypoint movement trace, several edge traces highlighting potential contact opportunities at various transmission ranges, and several group traces representing the pre-calculated connected components.
There are several supported store formats: a simple directory, a jar archive file, or using the java classpath.
A bus is associated to a specific type of event. Any number of sources may queue events on the bus, and any number of listeners may register to receive these events. The bus takes care of ensuring that events are always sent to the listeners in proper chronological order, but the sources may queue events at arbitrary times. For example, an easy way of combining two movement traces would be to feed their events to the same bus.
A runner is collection of sources and buses. Its job is to trigger the events from the source and then synchronize events and states across buses. It supports seeking and incrementing.
This project assumes a recent JDK (≥1.6) and uses maven. At the project root just run:
$ mvn install
This will build a single jar archive ditl.jar containing both the core and module classes.
A pre-built jar archive file is available for download: ditl-2.0.2.jar
The ditl.jar archive is an executable jar file. When calling it from the command-line, defining a shell (assuming bash) alias is useful:
$ alias ditl="java -jar /path/to/ditl.jar"
To see the built-in help, just type:
$ ditl --help
Most commands are of the form MODULE COMMAND [OPTIONS] ARG1 [ARG2..], where the first argument is usually the location of the trace store the command will be operating on. For example, in order to import a NS2 movement file (e.g., movement.ns2) as a trace named "movement" into the store "store.jar", one would use:
$ ditl graphs import-movement --movement movement --format ns2 store.jar movement.ns2
In fact, since "movement" and "ns2" are the default name and format, respectively, when importing movement into a store, the above can be further simplified to:
$ ditl graphs im store.jar movement.ns2
There are many available CLI commands. The Makefiles for the plausible mobility examples (under examples/plausible) present many different calls to the ditl cli interface.
When a movement trace is present in a store, the ditl library contains a built-in player to view it. It will automatically detect other traces (e.g., edge or static group traces) and add the relevant information to the player.
For example, the Plausible Mobility page serves the player as a Java Web Start application. Alternatively, you could download a sample dataset from the plausible mobility project and run it locally:
$ wget http://plausible.lip6.fr/rollernet.jar
$ ditl graphs play rollernet.jar
The following publications are based on this code.
- Temporal Reachability Graphs - ACM Mobicom 2012
- Push-and-Track: Saving Infrastructure Bandwidth Through Opportunistic Forwarding - Pervasive and Mobile Computing (August 2012)
- From Encounters to Plausible Mobility - Pervasive and Mobile Computing (April 2011)
This program is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.
This software 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 Library General Public License for more details.