Difference between revisions of "Rssi Demo"
m (→Java Application) |
Stevewchiang (talk | contribs) m (→Rssi Base) |
||
(2 intermediate revisions by 2 users not shown) | |||
Line 44: | Line 44: | ||
== Rssi Base == | == Rssi Base == | ||
− | RssiBase is the application | + | RssiBase is the application that will be put in a node connected to the serial port and will effectively read the RSSI. It uses the InterceptBase component to forward the messages over the radio but intercept the RssiMsg before it is forwarded and include the RSSI value in it. It contains some cryptic macros so it can work correctly with chips that use either the CC2420 or CC1000 radio. First, let us analyse the forward event: |
event bool RssiMsgIntercept.forward(message_t *msg, void *payload, uint8_t len) { | event bool RssiMsgIntercept.forward(message_t *msg, void *payload, uint8_t len) { | ||
Line 96: | Line 96: | ||
= Noise Floor Reading = | = Noise Floor Reading = | ||
To perform RSSI noise floor reading on platforms with the CC2420 radio, the HAL component CC2420ControlP should be used. On platforms which use the CC1000 radio, the CC1000RssiP component should be used. For detailed information on specifics, look up the module's documentation. | To perform RSSI noise floor reading on platforms with the CC2420 radio, the HAL component CC2420ControlP should be used. On platforms which use the CC1000 radio, the CC1000RssiP component should be used. For detailed information on specifics, look up the module's documentation. | ||
− | + | =Related Documentation= | |
+ | * [http://mythicalcomputer.blogspot.com/2008/11/tracking-using-rssi-application-in.html Simple One dimensional tracking with RSSI] | ||
= References = | = References = | ||
<references/> | <references/> | ||
+ | [[Category:Tutorials]] |
Latest revision as of 09:35, 11 October 2010
This lesson is to give an example on how to get Rssi readings from incoming packets. It consists of two applications:
- a simple application that periodically sends messages over the radio, and
- a modified version of BaseStation that includes the Rssi data on the payload of messages received over the radio before forwarding them over to the serial link.
It will also be shown how to get RSSI noise floor readings, to estimate the channel background noise when no node is transmitting.
Currently, this demo works only for motes that use CC1000 or CC2420 radio transceivers, but it should contain enough information for porting it to other chips that provide RSSI in a similar manner.
Contents
Introduction
RSSI is an acronym for Received Signal Strength Indication. It is a measure of the signal power on the radio link, usually in the units of dBm, while a message is being received. It can be used for estimating node connectivity and node distance (although the relation between distance and RSSI is noisy and not straightforward), among other things. Another usage of RSSI is to sample the channel power when no node is transmitting to estimate the background noise, also known as noise floor.
According to TinyOS' HAA <ref name="tep2">
TEP 2: Hardware Abstraction Architecture
</ref>
the RSSI data is not provided by the standard platform independent Hardware Interface Layer (represented interfaces Packet
and AMPacket
, as explained in TEP 116
<ref name="tep116">
TEP 116: Packet Protocols
</ref>
). RSSI must be accessed by a platform-specific HAL interface, as in the case of the CC2420 or by a specific field of the message_t
struct as defined in the platform_message.h
<ref name="tep111">
TEP 111: message_t
</ref> like in the case of the CC1000.
The RSSI values given by TinyOS are usually not in dBm units, and should be converted by the platform-specific relation to get meaningful data out of it.
Demo Application
Since RSSI is very platform-specific it will now be shown a hands-on demo to explain how to get RSSI readings from incoming packets. This demo is located in $TOSROOT/apps/tutorials/RssiDemo .
Intercept Base
InterceptBase is a modified version of the BaseStation
component that provides the Intercept
interface to allow the user application to inspect and modify radio and serial messages before they are forwarded to the other link, and to decide whether they shall be forwarded or not.
Sending Mote
SendingMote is the application to be put in the mote that sends the message whose RSSI will be read by the base. It contains a simple logic to periodically send a RssiMsg, as defined bellow:
typedef nx_struct RssiMsg{ nx_uint16_t rssi; } RssiMsg;
The RssiMsg is sent empty, it is the base that will include the RSSI value in the message.
Rssi Base
RssiBase is the application that will be put in a node connected to the serial port and will effectively read the RSSI. It uses the InterceptBase component to forward the messages over the radio but intercept the RssiMsg before it is forwarded and include the RSSI value in it. It contains some cryptic macros so it can work correctly with chips that use either the CC2420 or CC1000 radio. First, let us analyse the forward event:
event bool RssiMsgIntercept.forward(message_t *msg, void *payload, uint8_t len) { RssiMsg *rssiMsg = (RssiMsg*) payload; rssiMsg->rssi = getRssi(msg); return TRUE; }
It always forwards the messages (always returns true) but modifies the payload by including the rssi. Let us now analyse the getRssi(message_t *)
method:
#ifdef __CC2420_H__ uint16_t getRssi(message_t *msg){ return (uint16_t) call CC2420Packet.getRssi(msg); } #elif defined(CC1K_RADIO_MSG_H) uint16_t getRssi(message_t *msg){ cc1000_metadata_t *md =(cc1000_metadata_t*) msg->metadata; return md->strength_or_preamble; } #else #error Radio chip not supported! This demo currently works only \ for motes with CC1000 or CC2420 radios. #endif //__CC2420_H__
That code, for platforms with the CC2420 radio, gets the RSSI from the getRssi(message_t *)
method of the CC2420Packet
interface, provided by the CC2420ActiveMessageC
HAL component. For platforms with the CC1000 radio the RSSI is extracted from the packet metadata.
Java Application
A java application was called RssiDemo.java was created to see the results on the computer. For more explanations on how it works, look in the Mote-PC serial communication and SerialForwarder tutorial lesson, on which the file was based.
To build it simply give the make
command (no platform needed) in the $TOSROOT/apps/tutorials/RssiDemo directory and RssiDemo.class will be built. To run the application first install SendingMote in a mote, RssiBase in another which is connected to the computer's serial port and run it by issuing the java RssiDemo
command. Be sure to set the MOTECOM variable before, or using the -comm option. The output should be something like this:
Rssi Message received from node 1: Rssi = -14 Rssi Message received from node 1: Rssi = -1 Rssi Message received from node 1: Rssi = 2 Rssi Message received from node 1: Rssi = -2 Rssi Message received from node 1: Rssi = 2 Rssi Message received from node 1: Rssi = 0 Rssi Message received from node 1: Rssi = -2 Rssi Message received from node 1: Rssi = 2 Rssi Message received from node 1: Rssi = 2 Rssi Message received from node 1: Rssi = -10 Rssi Message received from node 1: Rssi = 1 Rssi Message received from node 1: Rssi = -6 Rssi Message received from node 1: Rssi = -4 Rssi Message received from node 1: Rssi = 0 Rssi Message received from node 1: Rssi = 0
The above test was performed with a tmote mini plus development board as base and a tmote invent as sending mote. It should be noted that this app prints only the raw RSSI values. The readings should be converted to dBm for more meaningful information.
Noise Floor Reading
To perform RSSI noise floor reading on platforms with the CC2420 radio, the HAL component CC2420ControlP should be used. On platforms which use the CC1000 radio, the CC1000RssiP component should be used. For detailed information on specifics, look up the module's documentation.
Related Documentation
References
<references/>