diffusion-3.1.2
所属分类:其他嵌入式/单片机内容
开发工具:Unix_Linux
文件大小:415KB
下载次数:8
上传日期:2011-11-23 10:23:08
上 传 者:
wowowawa
说明: 这是无线传感器网络中扩散协议diffusion的实现,对于研究无线传感器网络路由协议的朋友会有帮助
(This is a wireless sensor network to achieve diffusion-proliferation agreements, for the study of wireless sensor network routing protocols would help a friend)
文件列表:
diffusion-3.1.2\acconfig.h (1484, 2002-08-22)
diffusion-3.1.2\acinclude.m4 (15111, 2002-06-01)
diffusion-3.1.2\aclocal.m4 (18327, 2002-08-29)
diffusion-3.1.2\apps\gear\geo-attr.cc (1794, 2002-05-28)
diffusion-3.1.2\apps\gear\geo-attr.hh (1841, 2002-05-28)
diffusion-3.1.2\apps\gear\geo-routing.cc (37367, 2002-08-28)
diffusion-3.1.2\apps\gear\geo-routing.hh (8973, 2002-08-17)
diffusion-3.1.2\apps\gear\geo-tools.cc (4572, 2002-05-29)
diffusion-3.1.2\apps\gear\geo-tools.hh (3749, 2002-05-29)
diffusion-3.1.2\apps\gear\Makefile.am (1140, 2002-06-28)
diffusion-3.1.2\apps\gear\Makefile.in (10447, 2002-08-29)
diffusion-3.1.2\apps\Makefile.am (920, 2002-06-28)
diffusion-3.1.2\apps\Makefile.in (8635, 2002-08-29)
diffusion-3.1.2\apps\pingapp\Makefile.am (1946, 2002-06-28)
diffusion-3.1.2\apps\pingapp\Makefile.in (12837, 2002-08-29)
diffusion-3.1.2\apps\pingapp\ping.hh (1277, 2002-08-21)
diffusion-3.1.2\apps\pingapp\ping_common.cc (1145, 2002-08-21)
diffusion-3.1.2\apps\pingapp\ping_receiver.cc (4804, 2002-08-21)
diffusion-3.1.2\apps\pingapp\ping_receiver.hh (1768, 2002-08-21)
diffusion-3.1.2\apps\pingapp\ping_sender.cc (5951, 2002-08-21)
diffusion-3.1.2\apps\pingapp\ping_sender.hh (2322, 2002-08-21)
diffusion-3.1.2\apps\pingapp\push_receiver.cc (4889, 2002-08-21)
diffusion-3.1.2\apps\pingapp\push_receiver.hh (1768, 2002-08-21)
diffusion-3.1.2\apps\pingapp\push_sender.cc (4423, 2002-08-21)
diffusion-3.1.2\apps\pingapp\push_sender.hh (1955, 2002-08-21)
diffusion-3.1.2\apps\sysfilters\gradient.cc (38559, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\gradient.hh (7189, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\log.cc (3952, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\log.hh (1729, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\Makefile.am (1448, 2002-06-28)
diffusion-3.1.2\apps\sysfilters\Makefile.in (11522, 2002-08-29)
diffusion-3.1.2\apps\sysfilters\srcrt.cc (4606, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\srcrt.hh (1820, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\tag.cc (5393, 2002-05-29)
diffusion-3.1.2\apps\sysfilters\tag.hh (1767, 2002-05-29)
diffusion-3.1.2\bootstrap (114, 2002-03-21)
diffusion-3.1.2\CHANGES (5655, 2002-08-29)
diffusion-3.1.2\config\config.guess (33085, 2002-08-29)
diffusion-3.1.2\config\config.sub (25243, 2002-08-29)
diffusion-3.1.2\config\install-sh (5598, 2002-08-29)
... ...
Release Notes for Diffusion 3.1.2
---------------------------------
1. Compiling Diffusion
Starting with Diffusion 3.1, we use autoconf/automake to configure
diffusion.
There are several options that can be used with configure (for a
complete list, please type ./configure --help). Relevant command line
options for configure are:
--with-ethernet // Enables wired Ethernet support in diffusion
--with-wins2 // Enables support for the Sensoria WINSNG 2.0 radios
--with-sh4 // Enables support for using the sh4 cross compiler
// It assumes that the sh4 cross-compiler provided by
// Sensoria is already installed and on the user's path
--prefix=destination_path
// Enables the user to specify where the binaries will
// be installed (default is the test directory inside
// the distribution)
So, compiling diffusion for the Sensoria nodes, should be as simple as:
bash# ./configure --with-wins2 --with-sh4
bash# make
bash# make install
On the other hand, compiling for wired Ethernet on an i386 machine is:
bash# ./configure --with-ethernet
bash# make
bash# make install
Please remember to remove the config.cache file when compiling for a
different environment, as the file is not always deleted and may
contain misleading information for the configure script.
We tested compiling diffusion on both Red Hat Linux versions 7.2 and
7.3. It also compiles and runs on other versions of Unix.
2. Before Running Diffusion (Sensoria Hardware)
In order to use diffusion on the Sensoria nodes, you will have to have
streamd running on your system. We assume streamd will export the
device files /dev/rf/0/flink and /dev/rf/1/flink. Diffusion will not
start if these files are not present.
Starting with Sensoria software version 2.0, streamd is started
automatically when nodes boot, so there is no need to start it
manually for the two radios.
In addition, diffusion expects the radios to be configured as
base/remotes and clusters to be configured before it starts. Use
/dev/rf/*/command to manually configure each radio with the desired
topology (or use clusterd to set up a cluster automatically if a
specific topology is not important).
3. Setting up Node Ids
Diffusion uses a random ID for the each node. This behavior can be
overridden by setting the 'scadds_addr' environment variable to the
desired ID. Under bash, this can be done with:
bash# export scadds_addr=2
4. Configuration File (Wired Ethernet Environment)
Note that in the wired case, the file 'config.txt' (or an alternate
configuration file, specified with the -f flag) should be present and
contain a list of all directly connected nodes, one node in each
line. If connected nodes are running on a port other than the default
diffusion port (done by using the '-p' flag), this must be indicated
in the configuration file as well. When diffusion initializes, it will
display the list of connected nodes. Also, the configuration file can
include the link quality to each neighbor. It's an integer from 0 to
100 and will indicate the probability of a message sent by your node
to reach this neighbor. A sample configuration file is:
10.0.0.1 - 3400 - 100
10.2.4.1 - 30
10.3.12.4 - 85
In this case, we have three neighbors (10.0.0.1, 10.2.4.1 and
10.3.12.4), to which the probability of a packet getting lost is 0,
70% and 15% respectively. Note that the first neighbor (10.0.0.1) is
running on the port 3400 (instead of the default diffusion port, 2000).
Since the link quality is an integer from 0 to 100, and the port number
has to be above 1024, diffusion can correctly guess the second argument's
meaning if there are just 2 arguments in a config line.
5. Running Diffusion
To run diffusion, simply start the 'diffusion' main process followed
by the applications/filters desired. Please allow a few seconds for
diffusion to initialize before starting applications and filters. Be
sure to at least start the gradient module. For debugging, the log
filter can be used to print all messages arriving at the node.
To test if things are working, start diffusion, gradient and
ping_sender in a node. Then start diffusion, gradient and
ping_receiver in another node. ping_receiver should receive
ping_sender's messages after a few seconds. For example:
bash# diffusion &
bash# gradient &
bash# ping_receiver
To increase the amount of debug messages, you can use the '-d
debug_level' flag. A debug_level 10 will generate a lot of output. The
default value is 1.
Please note that if diffusion is run with the '-p port' flag,
all other applications will also need it (i.e. gradient -p port,
agent1 -p port, etc...).
Also, for running GEAR, you will need to start gear as well, So, the
list of processes to start is:
bash# diffusion &
bash# gradient &
bash# gear &
bash# your_application &
---------------------------------
Fabio Silva
Information Sciences Institute
University of Southern California
近期下载者:
相关文件:
收藏者: