API Remote AT Command Request

Hi, I am studying the book, ‘wireless sensor networks’ written by Oreilly.

The code is for lighting sensor with feedback. Remote LED lights if remoteindicator’s status is changed.
I am wondering how the remote LED turns on or off when ‘value’ is 0x4, 0x5. I marked the question with RED.

I looked through the datasheet, but not found how to make specific pin HIGH to turn on the LED.

Could you help me to understand it?

/*

  • *ROMANTIC LIGHTING SENSOR WITH FEEDBACK
  • detects whether your lighting is
  • setting the right mood and shows
  • you the results on the sensor module
  • USES PREVIOUSLY PAIRED XBEE ZB RADIOS
  • by Rob Faludi http://faludi.com
    /
    /

    *** CONFIGURATION ***
    SENDER: (REMOTE SENSOR RADIO)
    ATID3456 (PAN ID)
    ATDH -> set to SH of partner radio
    ATDL -> set to SL of partner radio
    ATJV1 -> rejoin with coordinator on startup
    ATD02 pin 0 in analog in mode with a photo resistor
    Figure 4-11. Romantic lighting sensor FEEDBACK SENSOR schematic
    106 | Chapter 4: Ins and Outs (don’t forget the voltage divider circuit–resistor
    to ground is good)
    ATD14 pin 1 in digital output (default low) mode with an
    LED from that pin to ground
    ATIR64 sample rate 100 millisecs (hex 64)
  • THE LOCAL RADIO MUST BE IN API MODE *
    RECEIVER: (LOCAL RADIO)
    ATID3456 (PAN ID)
    ATDH -> set to SH of partner radio
    ATDL -> set to SL of partner radio
    /
    #define VERSION “1.02”
    int LED = 11;
    int debugLED = 13;
    int analogValue = 0;
    int remoteIndicator = false; // keeps track of the desired remote
    // on/off state
    int lastRemoteIndicator = false; // record of prior remote state
    unsigned long lastSent = 0; // records last time the remote was
    // reset to keep it in sync
    void setup() {
    pinMode(LED,OUTPUT);
    pinMode(debugLED,OUTPUT);
    Serial.begin(9600);
    }
    void loop() {
    // make sure everything we need is in the buffer
    if (Serial.available() >= 23) {
    // look for the start byte
    if (Serial.read() == 0x7E) {
    //blink debug LED to indicate when data is received
    digitalWrite(debugLED, HIGH);
    delay(10);
    digitalWrite(debugLED, LOW);
    // read the variables that we’re not using out of the buffer
    // (includes two more for the digital pin report)
    for (int i = 0; i<20; i++) {
    byte discard = Serial.read();
    }
    int analogHigh = Serial.read();
    int analogLow = Serial.read();
    analogValue = analogLow + (analogHigh * 256);
    }
    }
    Romantic Lighting Sensor | 107 /
    • The values in this section will probably
    • need to be adjusted according to your
    • photoresistor, ambient lighting, and tastes.
    • For example, if you find that the darkness
    • threshold is too dim, change the 350 value
    • to a larger number.
      */
      // darkness is too creepy for romance
      if (analogValue > 0 && analogValue <= 350) {
      digitalWrite(LED, LOW);
      remoteIndicator = false;
      }
      // medium light is the perfect mood for romance
      if (analogValue > 350 && analogValue <= 750) {
      digitalWrite(LED, HIGH);
      remoteIndicator = true;
      }
      // bright light kills the romantic mood
      if (analogValue > 750 && analogValue <= 1023) {
      digitalWrite(LED, LOW);
      remoteIndicator = false;
      }
      // set the indicator immediately when there’s a state change
      if (remoteIndicator != lastRemoteIndicator) {
      if (remoteIndicator==false) setRemoteState(0x4);
      if (remoteIndicator==true) setRemoteState(0x5);
      lastRemoteIndicator = remoteIndicator;
      }
      // reset the indicator occasionally in case it’s out of sync
      if (millis() - lastSent > 10000 ) {
      if (remoteIndicator==false) setRemoteState(0x4);
      if (remoteIndicator==true) setRemoteState(0x5);
      lastSent = millis();
      }
      }

void setRemoteState(int value) { // pass either a 0x4 or 0x5 to turn
// the pin on or off
Serial.print(0x7E, BYTE); // start byte
Serial.print(0x0, BYTE); // high part of length (always zero)
Serial.print(0x10, BYTE); // low part of length (the number of bytes
// that follow, not including checksum)
Serial.print(0x17, BYTE); // 0x17 is a remote AT command
Serial.print(0x0, BYTE); // frame id set to zero for no reply
// ID of recipient, or use 0xFFFF for broadcast
Serial.print(00, BYTE);
Serial.print(00, BYTE);
Serial.print(00, BYTE);
Serial.print(00, BYTE);
Serial.print(00, BYTE);
Serial.print(00, BYTE);
Serial.print(0xFF, BYTE); // 0xFF for broadcast
Serial.print(0xFF, BYTE); // 0xFF for broadcast
// 16 bit of recipient or 0xFFFE if unknown
Serial.print(0xFF, BYTE);
Serial.print(0xFE, BYTE);
Serial.print(0x02, BYTE); // 0x02 to apply changes immediately on remote
// command name in ASCII characters
Serial.print(‘D’, BYTE);
Serial.print(‘1’, BYTE);
// command data in as many bytes as needed
Serial.print(value, BYTE);
// checksum is all bytes after length bytes
long sum = 0x17 + 0xFF + 0xFF + 0xFF + 0xFE + 0x02 + ‘D’ + ‘1’ + value;
Serial.print( 0xFF - ( sum & 0xFF) , BYTE ); // calculate the proper checksum
}

Hi,

Create an online support request at the following link, http://www.digi.com/login?ReturnUrl=%2Fsupport%2Feservice
Digi folks can help you.