XBee Quick Reference Guide PDF

Download as pdf or txt
Download as pdf or txt
You are on page 1of 1

S2

XBee Roles

VCC 3.3v Data Out Data In DIO12 Reset RSSI PWM/DIO10 DIO11 [reserved] DTR/Sleep_RQ/DIO8 GND

20 Digi International

XBee
10 11

AD0/DIO0/CB AD1/DIO1 AD2/DIO2 AD3/DIO3 RTS/DIO6 Associate/DIO5 VREF ON/Sleep/DIO9 CTS/DIO7 DIO4

XBee S2 Quick Reference Guide


C R E

Operating Voltage: 2.1 3.6V Operating Current: [email protected] Indoor range: 40 Meters Line of sight range: 120 Meters Max Analog Pin Reading: 1.2V

IEEE 802.15.4 = Zigbee Protocol. XBee is a microcontroller made by digi which uses the Zigbee protocol. The XBee uses 3.3V and has a smaller pin spacing than most breadboards/proto boards. Because of this, it is often useful to purchase a kit to interface R the XBee with a breadboard. Digital I/O pins: 11 RF Data Rate: 250kbps Analog input pins: 4 Throughput speed: 35kbps Mesh routable Frequency: ISM 2.4GHz Self Healing network OK Temp: -40 to 85C E Firmware: ZB ZigBee

Sept/2012 http://tunnelsup.com Coordinator 1 required in every network In charge of setting up the network Can never sleep Router multiple may exist Can relay signals from other routers/EPs Can never sleep End Point multiple may exist Cannot relay signals Can sleep to save power

Specs

Transparent Communication through the XBee. If data is not generated from the XBee itself then both XBees should be set to AT. Command Communication to the XBee. If one XBee is sensing data, that XBee should be in AT mode while the receiving one should be in API mode. Connect the XBee to a TTL Serial FTDI adapter OR Arduino hack: Connect RX to RX, TX to TX, RESET to ground to bypass the Arduino entirely and get serial to XBee. Use the free X-CTU software to configure the XBee. Baud: 9600 FC: Hardware Data Bits: 8 Parity: None Stop Bits: 1

XBee Modes

Arduino Connectivity: Arduino TX connects to XBee RX (Data in) Arduino RX connects to XBee TX (Data out) Arduino Integration: Data sent to Serial.print() will go out TX port of Arduino which is then connected to the RX port of XBee. If XBee is in AT mode it will transmit it wirelessly. Data received from XBee will be sent to the Serial.

XBee Setup API format for Remote AT Command Request Pin Settings Basic Settings

Arduino Example: Read an analog value using API // Remote XBee: AT, Base XBee: API if (Serial.available() >= 21) { // Make sure the frame is all there if (Serial.read() == 0x7E) { // 7E is the start byte PAN ID The network to communicate over. If 0, the XBee will join any. for (int i = 1; i<19; i++) { // Skip ahead to the analog data DH/DL Destination Serial number. Used to send to a specific XBees byte discardByte = Serial.read(); Serial. Set to 0 to send to just the Coorindator. Set to 0x0000000000FFFF } to broadcast. int analogMSB = Serial.read(); // Read the first analog byte data JV Router/EP should be set to 1 so it rejoins the network on startup int analogLSB = Serial.read(); // Read the second byte int analogReading = analogLSB + (analogMSB * 256); For pin settings to work, receiver XBee must be in API mode } D0 Set pin 0 to start sensing } IR Collect data on sensing pins every XX millisecs

Byte Example Description Arduino Example: Change the pin setting on a remote Xbee 0 0x7e Start byte Indicates beginning of data frame // Remote XBee: AT, Base XBee: API 1 0x00 Length Number of bytes (ChecksumByte# 1 2) Serial.write(0x7E); // Sync up the start byte 2 0x10 Serial.write((byte)0x0); // Length MSB (always 0) 3 0x17 Frame type - 0x17 means this is a AT command Request Serial.write(0x10); // Length LSB 4 0x52 Frame ID Command sequence number Serial.write(0x17); // 0x17 is the frame ID for sending an AT command 5 0x00 64-bit Destination Address (Serial Number) Serial.write((byte)0x0); // Frame ID (no reply needed) 6 0x13 MSB is byte 5, LSB is byte 12 Serial.write((byte)00); // Send the 64 bit destination address 7 0xA2 Serial.write((byte)00); // (Sending 0x000000000000FFFF (broadcast)) 8 0x00 0x0000000000000000 = Coordinator Serial.write((byte)00); 9 0x40 0x000000000000FFFF = Broadcast Serial.write((byte)00); 10 0x77 Serial.write((byte)00); 11 0x9C Serial.write((byte)00); 12 0x49 Serial.write(0xFF); 13 0xFF Destination Network Address Serial.write(0xFF); 14 0xFE (Set to 0xFFFE to send a broadcast) Serial.write(0xFF); // Destination Network 15 0x02 Remote command options (set to 0x02 to apply changes) Serial.write(0xFE); // (Set to 0xFFFE if unknown) 16 0x44 (D) AT Command Name (Two ASCII characters) Serial.write(0x02); // Set to 0x02 to apply these changes 17 0x02 (2) Serial.write(D); // AT Command: D1 18 0x04 Command Parameter (queries if not present) Serial.write(1); 19 0XF5 Checksum Serial.write(0x05); // Set D1 to be 5 (Digital Out HIGH) long chexsum = 0x17 + 0xFF + 0xFF +0xFF + 0xFE + 0x02 + D + 1 + 0x05; Byte Example Description Serial.write( 0xFF (chexsum & 0xFF)); // Checksum 0 0x7e Start byte Indicates beginning of data frame 1 0x00 Length Number of bytes (ChecksumByte# 1 2) Endpoints can sleep to save 0 Disabled 2 0x14 power. An endpoint that only 1 N/A 3 0x92 Frame type - 0x92 indicates this will be a data sample wakes up every 5 minutes to 2 ADC 4 0x00 64-bit Source Address (Serial Number) send data may only be awake 3 Digital IN 5 0x13 MSB is byte 4, LSB is byte 11 for 6 seconds a day. 4 Digital OUT, LOW 6 0xA2 SM 4 = Cyclic sleep 5 Digital OUT, HIGH 7 0x00 SP Sleep time (up to 28 secs) 8 0x40 SN Number of sleep cycles 9 0x77 ST Time awake 10 0x9C 11 0x49 12 0x36 Source Network Address 16 Bit First Byte 13 0x6A n/a n/a n/a D12 D11 D10 n/a n/a 14 0x01 Receive Opts. 01=Packet Acknowledged. 02=Broadcast packet Second Byte 15 0x01 Number of sample sets. Always set to 1 due to XBEE limitations D7 D6 D5 D4 D3 D2 D1 D0 16 0x00 Digital Channel Mask Indicates which pins are set to DIO Example: 17 0x20 0x00 0x13 = 0000 0000 0000 1101 18 0x01 Analog Channel Mask Indicates which pins are set to ADC Pins D3, D2 and D0 19 0x00 Digital Sample Data (if any) Reads the same as Digital Mask 20 0x14 (volt) n/a n/a n/a A3 A2 A1 A0 21 0x04 Analog Sample data (if any) Example: 22 0x25 There will be two bytes here for every pin set for ADC 0x05 = 0000 0101 = Pin A2 and A0 23 0xF5 Checksum(0xFF - the 8 bit sum of the bytes from byte 3 to this byte) Analog Digital Ch Mask Ch Mask Sleep Mode Pin I/O Options

API format for I/O Data Sample RX Indicaton

You might also like