1. Field of the Invention
The present invention relates to a load control system having a plurality of control devices and operable to control the amount of power delivered to a plurality of electrical loads from an AC power source, and more particularly, to a novel communication protocol for allowing the control devices of the load control system to communicate with each other.
2. Description of the Related Art
Typical load control systems are operable to control the amount of power delivered to an electrical load, such as a lighting load or a motor load, from an alternating-current (AC) power source. A load control system generally comprises a plurality of control devices coupled to a communication link to allow for communication between the control devices. The control devices of a lighting control system include load control devices operable to control the amount of power delivered to the loads in response to digital messages received across the communication link, or in response to local inputs, such as user actuations of a button. Further, the control devices of a lighting control system often include one or more keypad controllers that transmit commands across the communication link in order to control the loads coupled to the load control devices. An example of a lighting control system is described in greater detail in commonly-assigned U.S. Pat. No. 6,803,728, issued Oct. 12, 2004, entitled SYSTEM FOR CONTROL OF DEVICES, which is incorporated herein by reference in its entirety.
Many prior art lighting control systems use polling techniques to allow the control devices to communicate with each other. In order to execute the polling technique, one control device of the lighting control system must first establish itself as a “master” device. Then, the master device is operable to sequentially transmit poll messages to and receive responses from each of the other control devices in the control system. The response to the poll message may comprise an event to report (e.g., the actuation of a button on a keypad or another high-priority event) or simply a status update message. When a button of a keypad is actuated, the load control devices typically control the lighting loads appropriately. Since the user expects the lighting loads to respond quickly to the actuation of the button of the keypad, the response time of the lighting control system must be rather small, such that the user does not perceive a significant delay.
The master device must complete a polling cycle (i.e., transmitting a poll message to and then receiving a response from each of the control devices in the lighting control system) before repeating the polling cycle. Thus, there can be a rather long time period between when a control device has a high-priority message (corresponding to a high-priority event such as a button actuation) ready to transmit and when the master device polls the control device, thus allowing the control device to transmit the high-priority message. In order to process high-priority messages with an appropriate response time, prior art lighting control systems executing the polling technique either have been limited to a smaller number of control devices in the system (e.g., 32 control devices) or have required a high baud rate (e.g., 125 kbps) to transmit the digital messages between a larger number of control devices (e.g., 64 control devices). When the lighting control systems use a high baud rate, the control devices must be wired together using specific wiring topologies, e.g., a daisy-chain topology, which complicates the installation procedure of the lighting control system. Likewise, limiting the number of control devices that a master device can communicate with to a small number complicates the installation procedure. A lighting control system that is limited to only 32 control devices require the introduction of advanced control devices, such as multi-link processors, to scale beyond the limited number of control devices.
Therefore, there exists a need for a robust communication protocol that uses a polling technique and a low enough baud rate to provide for a free-wiring scheme, while still allowing special events to be executed in a timely manner.
According to the present invention, a method of transmitting a high-priority digital message via a communication link comprises the steps of: (1) transmitting regular-priority digital messages between a plurality of control devices; (2) signaling that one of the plurality of control devices has a high-priority digital message to transmit; (3) suspending the transmission of the regular-priority digital messages between the plurality of control devices; and (4) transmitting the high-priority digital message during the suspension of the transmission of the regular-priority digital messages.
According to a first embodiment of the present invention, a method of transmitting a high-priority digital message from a second control device to a first control device comprises the steps of: (1) the first device transmitting a first message; (2) the second device transmitting a high-priority break character during a predetermined time period following the first device transmitting the first message; (3) the first device transmitting a second message to the second device in response to receiving the high-priority break character; and (4) the second device transmitting the high-priority digital message to the first device in response to the second message.
According to a second embodiment of the present invention, a method of transmitting a high-priority digital message from a second control device to a first control device comprises the steps of: (1) the first device beginning to transmit a regular-priority digital message during a first predetermined time slot; (2) the second device transmitting a break character during a predetermined time period following the end of the regular-priority message; (3) the first device suspending the transmission of regular-priority digital messages in response to receiving the break character; and (4) the second device beginning to transmit the high-priority digital message during a second predetermined time slot while the first device has suspended the transmission of regular-priority digital messages.
The present invention further provides a method of polling a plurality of control devices on a communication link. Each of the plurality of control devices has a unique Poll ID. The method comprising the steps of: (1) sequentially transmitting a poll message to each of the plurality of control devices using the Poll ID of each control device; (2) transmitting a break character in a predetermined time period following one of the poll messages; (3) suspending the sequential transmission of poll messages in response to the step of transmitting a break character; (4) determining which one of the plurality of control devices transmitted the break character; (5) transmitting a request message to the one of the plurality of control devices that transmitted the break character; and (6) transmitting from the one of the plurality of control devices that transmitted the break character a high-priority digital message in response to the request message.
In addition, the present invention provides a method of polling a plurality of control devices by a master device selected from said plurality of control devices. Each of the plurality of control devices is coupled to a communication link and includes a unique Poll ID. The method comprises the steps of: (1) the master device sequentially transmitting a poll message to each control device marked active in a list of Poll IDs, the poll message including a status request; (2) each of the control devices responding to the poll message when the Poll ID of the device matches the Poll ID of the poll message; (3) one of the control devices transmitting a high-priority request; (4) the master device interrupting the sequential transmission of poll messages when the high-priority request is received; and (5) performing a binary search to find the Poll ID of the control device that provided the high-priority request.
According to another aspect of the present invention, a method of transmitting a high-priority digital message between a plurality of control devices via a communication link comprises the steps of: (1) operating the communication link in a normal mode of operation by transmitting regular-priority digital messages between the plurality of control devices; (2) signaling that one of the plurality of control devices has a high-priority digital message to transmit; (3) changing the communication link to a high-priority mode of operation in response to the step of signaling, the transmission of regular-priority digital messages suspended in the high-priority mode of operation; and (4) transmitting the high-priority digital message while the communication link is in the high-priority mode of operation.
The present invention further provides a control device for a lighting control system having a communication link. The control device comprises a communication circuit, a controller, and an input. The communication circuit is operable to be coupled to the communication link for transmission and receipt of digital messages. The controller is coupled to the communication circuit and operable to control the transmission and receipt of the digital messages. The input is coupled to the controller, such that the controller is operable to transmit a first message having a regular-priority and further operable to transmit a second message having a high-priority in response to the input.
Other features and advantages of the present invention will become apparent from the following description of the invention that refers to the accompanying drawings.
The foregoing summary, as well as the following detailed description of the preferred embodiments, is better understood when read in conjunction with the appended drawings. For the purpose of illustrating the invention, there is shown in the drawings an embodiment that is presently preferred, in which like numerals represent similar parts throughout the several views of the drawings, it being understood, however, that the invention is not limited to the specific methods and instrumentalities disclosed.
The load control device 110 is operable to communicate with the electronic drive units 112 and the keypads 120 via a communication link 114 using a novel communication protocol according to the present invention. The communication link 114 preferably comprises a wired four-wire RS-485 communication link having a baud rate of 41.67 kbps. Each communication link 114 preferably comprises a first wire for a common connection, a second wire for providing a direct-current (DC) voltage VLINK (e.g., 24 VDC) to power the control devices on the device communication link, and third and fourth wires (i.e., data wires) for carrying digital messages between the control devices. The third and fourth wires carry differential communication signals, i.e., MUX and MUXBAR signals, according to the RS-485 protocol.
The load control device 110 and the electronic drive units 112 are responsive to digital messages received from the plurality of keypads 120. A user is able to adjust the intensities of the lighting loads 104 or to select a lighting preset of the load control device 110 using the keypads 120. The user is also able to open or close the motorized roller shades 106, adjust the position of the shade fabric of the roller shades, or set the roller shades to preset shade positions using the keypads 120.
A communication circuit 156, e.g., an RS-485 transceiver, is coupled to the data wires MUX and MUXBAR of the communication link 114. The controller 150 is coupled to the communication circuit 156, such that the controller 150 is operable to transmit and receive digital messages via the communication link 114. The controller 150 also receives inputs from a plurality of buttons 158, and controls a plurality of visual indicators, e.g., LEDs 160. The controller 150 is coupled to a memory 162 for storage of the configuration information of the keypad 120.
The load control device 110 and the electronic drive units 112 have similar structures to the keypads 120. In addition to the functional blocks shown in
The control devices, i.e., the load control device 110, the electronic drive units 112, and the keypads 120, communicate with each other in accordance with the protocol of the present invention using a polling procedure 200 (as shown in
The control devices do not include DIP switches for setting the addresses, functionalities, and configurations of the control devices. Preferably, each of the control devices has a unique 32-bit serial number, which is assigned to the device during manufacture. The serial number is used to determine the programming of the lighting control system 100. For example, if one of the keypads is associated with the lighting control device 110, the lighting control device stores the serial number of the keypad in memory.
Since the serial numbers are rather large numbers, the master device does not include the serial number of the slave device to which the poll message is directed with each transmitted poll message. The master device transmits the poll messages to the slave devices on the communication link 114 using unique semi-permanent single-byte Poll IDs (i.e., unique link addresses). The serial number is used to determine the Poll ID of each control device, such that each control device on the communication link 114 has a different Poll ID. Preferably, the control devices store the Poll ID in the memory 162. The master device periodically broadcasts a Poll-ID-Request poll message (i.e., a non-standard poll message) to allow those slave devices on the communication link 114 that do not have a Poll ID to request a Poll ID.
The master device maintains a list of control devices present on the link and transmits poll messages to only those devices. If the master device is not transmitting standard poll messages to a specific slave device, the slave device is operable to drop its Poll ID and then request a new Poll ID. In response to the request for a new Poll ID, the master device determines the serial number of the control device and transmits a new Poll ID to the control device. The master device then has the new Poll ID stored in the list of control devices and accordingly begins transmitting poll messages to the control device. Also, a control device on the communication link 114 is operable to determine that another control device has the same Poll ID, to subsequently drop the Poll ID, and to acquire another Poll ID. The master device is operable to re-use those Poll IDs that control devices on the communication link 114 have dropped.
According to the present invention, the sequential polling of each device on the communication link 114 (i.e., the normal mode of operation) may be suspended if any of the control devices has a high-priority message to transmit. A high-priority message may be transmitted in response to a high-priority event occurring at the control device, for example, an actuation of one of the buttons 158 of one of the keypads 120. To signal a high-priority request (HPR), each of the control devices is operable to transmit a “break character” on the communication link 114 (i.e., to “assert the link”) during a predetermined HPR time period following the end of a standard poll message transmitted to any of the control devices. For example, if the communication link 114 is one in which the link is at a low potential (i.e., substantially zero volts) when no control devices are transmitting digital messages on the communication link (i.e., when the link is in an idle state), the control device may drive the communication link high for a “byte-time” to transmit a break character. A byte-time is defined herein as the amount of time required to transmit one byte of data at the operating baud rate. In response to receiving a high-priority request, the master device is operable to change the communication link 114 to a high-priority mode of operation in which the transmissions of regular-priority messages are suspended. Regular-priority messages comprise, for example, a response to a standard poll message and a response to a Poll-ID-Request poll message.
Multiple control devices may simultaneously transmit the break character, and thus, the transmission of break characters is considered as “wired-OR” logic. The master device is operable to determine which of the control devices transmitted the break characters and have high-priority events to report using an HPR binary search routine 300 (shown in
The master device and the other control devices coupled to the communication link 114 are all operable to receive the high-priority events using a message processing procedure 400 (shown in
A repeater time period follows the end of the standard poll message 180 and is two byte-times in length. The length of the communication link 114 of the load control system 100 may be effectively lengthened using one or more repeater devices (not shown), which are control devices that are operable to buffer the poll messages onto additional lengths of wiring of the communication link 114. The electrical hardware of the repeater devices introduces a delay from when the repeater devices finish buffering the poll messages to when the repeater devices return the communication link 114 to the idle state. Therefore, the use of repeater devices to electrically buffer the poll messages 180 introduces some delay into when the control devices on the link are operable to begin transmitting digital messages. The repeater period after the standard poll message 180 is provided to allow for this delay, i.e., for the repeater devices to return the communication link 114 to the idle state. Repeater devices are described in greater detail in commonly-assigned U.S. Provisional Patent Application Ser. No. 60/874,166, filed Dec. 11, 2006, entitled LOAD CONTROL SYSTEM HAVING A PLURALITY OF REPEATER DEVICES, the entire disclosure of which is hereby incorporated by reference.
The HPR time period, also having a length of two byte-times, immediately follows the repeater time period. During the HPR time period, any control devices that have high-priority events to report are operable to transmit an HPR break character on the communication link 114. If an HPR break character is transmitted, the polled control device does not respond to the standard poll message 180. Therefore, the control device to which the standard poll message 180 was transmitted is operable to transmit the response 185 only if no control devices transmit an HPR break character during the HPR time period.
If no control devices transmit an HPR break character during the HPR time period, the responding control device is operable to begin transmitting the response 185 beginning during a two-byte response time period. The response 185 has a variable length. For example, a simple “I'm Here” response may comprise only two bytes R1, R2 as shown in
Next, the master device determines the Poll ID of the control devices that transmitted the HPR break characters using the HPR binary search routine 300.
At step 310, the controller 150 initializes the values of the minimum range value ID_LO to the minimum search value MIN_VALUE, the maximum range value ID_HI to the maximum search value MAX_VALUE, and the midpoint value ID_MID to the midpoint of the search range, i.e.,
ID_MID=FLOOR[(MAX_VALUE−MIN_VALUE)/2+MAX_VALUE]. (Equation 1)
The function FLOOR returns the next lowest integer (i.e., rounds down), e.g., FLOOR(4.5)=4. At step 312, the master device transmits an HPR-Search poll message to the control devices on the communication link 114. The HPR-Search poll message is a non-standard poll message (as shown in
If the maximum range value ID_HI is not equal to the minimum range value ID_LO at step 320, the search is not complete. The midpoint value ID_MID is set equal to the midpoint of the new search range, i.e.,
ID_MID=FLOOR[(ID—HI−ID—LO)/2+ID_LO], (Equation 2)
at step 322 and the HPR binary search routine 300 loops to transmit another HPR-Search poll message to the narrowed range of the control devices at step 312. If the maximum range value ID_HI is equal to the minimum range value ID_LO at step 320 (i.e., the search is complete) and the minimum range value ID_LO is not equal to the maximum search value MAX_VALUE at step 324, the controller 150 has found a control device that has a high-priority event to report. Accordingly, the controller 150 stores the minimum range value ID_LO in memory at step 326 since the control device having the Poll ID equal to the value of the minimum range value ID_LO has a high-priority event to report, and the HPR binary search routine 300 exits. If the minimum range value ID_LO is equal to the maximum search value MAX_VALUE at step 324, the controller 150 determines that no device was found by the HPR binary search routine 300 at step 328. Even though a binary search is preferably used by the polling procedure 200 to locate the control devices that transmitted HPR break characters, those skilled in the art will appreciate that other searching procedures could be used to locate the control devices.
Referring back to
In order to prevent a single control device from monopolizing the bandwidth of the communication link 114 (e.g., if a user is repeatedly pressing a button on a keypad), a control device that just transmitted a high-priority message will not report a high-priority event again until normal polling continues. At that time, the control device is operable to once again transmit an HPR break character to report the high-priority event. This anti-bandwidth-monopolization provision of the protocol is described in greater detail with reference to the message processing procedure 400 of
When all control devices having high-priority events to transmit have been found, the master device resumes polling the communication link 114 with the Poll ID of the slave device that the poll message transmitted to before processing the high-priority request. Specifically, at step 220, the controller 150 retrieves the stored device from the memory (i.e., the present device that was stored in memory at step 214) and transmits a poll message to this control device at step 210.
If the master device does not detect an HPR break character at step 212 before the end of the HPR period at step 221, a determination is made at step 222 as to whether the master device has received a response to the poll message that was transmitted at step 210. If so, the master device determines whether the response is a “good response” at step 224, i.e., the master device determines whether the received message has a correct message length and a valid checksum. If a specific control device transmits a predetermined number of consecutive, incoherent messages to the master device (e.g., ten incoherent messages), the master device changes the status of the device to “missing-in-action” (MIA), i.e., ceases to transmit polling messages to the control device during the polling procedure 200. Specifically, if the response is not a good response at step 224, the master device increments a strike counter for the control device at step 226. The master device maintains a unique strike counter for each slave device on the communication link 114. If the strike counter for the present control device has exceeded the predetermined number, e.g., ten, at step 228, the master device changes the status of the control device to MIA at step 230 and transmits a Drop-ID message at step 231 to the control device that is missing-in-action. If a control device receives the Drop-ID message and has the Drop-ID message included in the Poll ID, the control device drops the present Poll ID and is thus ready to request and receive a new Poll ID. If the master device determines that the response is a good response at step 224, the master device clears the strike counter for the control device at step 232.
The master device periodically, e.g., every ten polling rounds, allows any control devices that do not have a Poll ID to request a Poll ID. If the master device has polled all devices ten times at step 234, the master device executes a Poll-ID-Request routine 350, which is shown in
If the master device receives a Poll ID break character at step 354, the master device executes a serial number binary search routine 300′ to determine the control device(s) that require a Poll ID. The serial number binary search routine 300′ is shown in
If the master device finds a control device that requires a Poll ID at step 356, the master device transmits to the found control device at step 358 a Poll-ID-Assign message, which includes the first available Poll ID, using the serial number of the control device. The master device continues to assign Poll IDs at step 358 until the Poll ID binary search routine 300′ does not locate any devices that require a Poll ID at step 356. If the master device does not receive a Poll ID break character at step 354 or if the master device does not find any more control devices that require a Poll ID at step 356, the Poll-ID-request routine 350 exits.
Referring back to
Since multiple control devices may have transmitted a Poll ID break character at step 416, the master device executes the serial number binary search routine 300′ to locate the control devices that require a Poll ID. If the control device has received an SN-Search poll message at step 418, a determination is made at step 420 as to whether the serial number of the control device is less than or equal to the midpoint value ID_MID. If not, the procedure 400 simply exits. Otherwise, the control device transmits a search break character at step 422 and the procedure 400 exits. The master device uses the transmission of the search break character at step 422 to narrow the searching range of the serial number binary search routine 300′. When the master device narrows the search to one control device, the master device transmits a Poll-ID-Assign poll message to the found control device. If the control device receives a Poll-ID-Assign poll message at step 424 and the serial number contained in the Poll-ID-Assign poll message is the serial number of the control device at step 425, the control device stores the Poll ID included in the poll message in memory at step 426 and the procedure 400 exits. If the control device does not receive a Poll-ID-Assign poll message at step 424 or if the serial number contained in the Poll-ID-Assign poll message is not the serial number of the control device at step 425, the procedure 400 simply exits.
Referring to
If the received poll message does not include the Poll ID of the polled control device at step 432, a determination is made at step 434 as to whether the control device has a high-priority event to report. If the control device was not polled at step 432 and has a high-priority event to report at step 434, the control device waits at step 435 for two-byte times after the end of the received standard poll message, i.e., until the start of the HPR time period. During the HPR time period, the control device transmits an HPR break character on the communication link 114 at step 436. Alternatively, if the received poll message includes the Poll ID of the control device and the control device has a high-priority event to report, but the control device does not receive an HPR break during the HPR time period, the control device simply transmits the high-priority message as a response to the standard poll message received at step 428 as will be described in greater detail below. Further, if the received poll message includes the Poll ID of the control device, the control device has a high-priority event to report, and the control device receives an HPR break during the HPR time period, the polled control device does not transmit the high-priority message as a response to the poll message, but instead responds to the HPR search routine 300 executed by the master control.
If the control device does not receive, for a predetermined number of received standard poll messages, a standard poll message that includes the Poll ID of the control device, i.e., the master device is not polling the control device, the control device is operable to drop the Poll ID and obtain a new Poll ID. Specifically, if the control device receives a predetermined number of Poll-ID-Request poll messages (which are transmitted after every 10th polling round), e.g., two (2) Poll-ID-Request poll messages, the control device will drop its Poll ID. The control device uses a Poll_Cycle counter to keep track of how many Poll-ID-Request poll messages have been transmitted since the control device was last polled.
Specifically, if the received poll message includes the Poll ID of the control device at step 430, the control device sets the Poll_Cycle counter equal to two (2) at step 438 and waits for two byte-times at step 440 until the HPR time period begins. The control device listens for an HPR break character during the HPR period at step 442 until the end of the HPR period arrives at step 444. If the control device hears an HPR break character at step 442, the control device exits the procedure 400 without responding to the poll message. If the control device has a high-priority event to report at step 442, the control device subsequently joins in to the HPR search routine 300 executed by the master control.
In order to determine if any other control devices on the communication link 114 have the same Poll ID, the control device periodically listens for transmissions on the communication link rather than transmitting a response to a received standard poll message during the time period that the control device is operable to begin transmitting the response. The control device preferably chooses at random not to respond to one of the standard poll messages in the range of the 16th through 32nd standard poll message. If the control device does not hear an HPR break character at step 442 before the end of the HPR period at step 44, a determination is made at step 445 as to whether the control device should execute the random non-response to the standard poll message, i.e., to listen to the communication link 114 rather than responding to the standard poll message. If so, the control device listens for a response to the standard poll message from another control device at step 446. If the control device hears a response at step 446, the control device drops the present Poll ID at step 448 and eventually obtains another Poll ID through the Poll-ID-Request routine 350. If the control device should not listen on the communication link 114 at step 445 and the control device has a high-priority event to report at step 450, the control device transmits the high-priority event at step 451 and the procedure 400 exits. If the control device does not have a high-priority event to report at step 450, the control device transmits at step 452 a response to the standard poll message received at step 428.
If the control device has not received a standard poll message at step 428, the control device operates to process non-standard poll messages, i.e., responses to poll messages, HPR-Search poll messages, Link-ID-Request poll messages, etc. as shown in
In response to receiving the HPR break character transmitted at step 436, the master device executes the HPR binary search routine 300 to locate the control devices that have high-priority events to report. Specifically, if the control device has a high-priority event to report at step 454 and if the control device receives the HPR-Search poll message at step 456, a determination is made at step 458 as to whether the Poll ID of the control device is less than or equal to the midpoint value ID_MID. If the Poll ID of the receiving control device is within the search range of the HPR binary search routine 300, the control device transmits a search break character on the communication link at step 460.
When the master device determines the Poll ID of a control device that has a high-priority event to report, the master device transmits a Report-HPR poll message to the control device. If the control device receives a Report-HPR message at step 462 and the HPR_LOCK flag is not set at step 464, the control device transmits the high-priority event to the control devices on the communication link 114 at step 466. The control device then sets the HPR_LOCK flag at step 468, such that the control device is not able to transmit another high-priority event until normal polling begins again.
If the control device does not have a high-priority event to report at step 454, but has received at step 470 a response to a standard or non-standard poll message, the control device appropriately processes the response at step 472. For example, if a user actuated a button on one of the keypads 120, the keypad 120 may transmit a high-priority message corresponding to the selection of a first lighting preset. When the control device receives the high-priority message at step 470, the control device may be responsive to the first lighting preset at step 472, e.g., the control device may illuminate an LED or control a lighting load 104 in accordance with the first lighting preset. The processing of commands of a load control system is described in greater detail in the '728 patent.
If the control device has not received a response to a standard or non-standard poll message at step 470, but the control device has received a Poll-ID-Request poll message at step 474, the controller 150 decrements the variable Poll_Cycle counter by one at step 476. If the variable Poll_Cycle counter is equal to zero at step 478, the control device drops the Poll ID at step 480. Otherwise, the procedure 400 simply exits. If the control device has not received a Poll-ID-Request poll message at step 480, a determination is made at step 482 as to whether the received message is a Drop-ID message. If the control device received a Drop-ID message at step 482 and the Drop-ID message contains the Poll ID of the polled control device, the polled control device drops the present Poll ID at step 480 and the procedure 400 exits. If the control device did not receive a Drop-ID message at step 482 or if the Drop-ID message did not contain the Poll ID of the polled control device, the procedure 400 simply exits.
t1=2 sec+(20 msec·Poll ID). (Equation 3)
Next, the control device listens for communication (i.e., link activity) on the communication link 114 at step 156 until the timer exceeds the first time t1 at step 518. If the timer exceeds the first time t1 at step 518, the control device begins to operate as the master device at step 520. Next, the control device executes the Poll-ID-Request routine 350 to allow other control devices on the communication link 114 to request a Poll ID, if needed. Then, the startup procedure 500 exits, at which time the control device operating as a master device begins executing the polling procedure 200. If the control device detects link activity at step 516, the control device simply operates as a slave device (i.e., not as the master device) at step 522 and the startup procedure 500 exits.
If the control device does not have a Poll ID stored in the memory 162 (or does not have a memory to store the Poll ID) at step 512, the controller sets a second time t2 at step 524, such that
t2=4.02 sec+(600 msec·SNLOW-12-BITS), (Equation 4)
where SNLOW-12-BITS is the value of the lower 12 bits of the serial number of the control device. According to Equation 2, the second time t2 is always greater than the first time t1 to allow a control device having a Poll ID to become the master device before allowing a control device not having a Poll ID. The control device waits until link activity is detected at step 526 or the timer exceeds the second time t2 at step 528, at which time the control device sets the Poll ID as zero (0) at step 530. The control device then begins operating as the master device at step 520 and executes the Poll-ID-Request routine 350. If the control device detects communication on the communication link 114 at step 526, the control device operates as a slave device at step 532 and the startup procedure 500 exits.
The lighting control system 100 as shown in and described with reference to
According to a second embodiment of the present invention, the lighting control system 100 does not require a master device in order to allow for the transmission of regular-priority and high-priority messages between the control devices. Rather, each of the control devices of the lighting control system 100 according to the second embodiment is operable to begin transmitting a digital message during a unique predetermined time slot. Preferably, each control device comprises a timer and is operable to keep track of the present time slot.
After the stop character is the NACK period (also 240 μsec in length), during which any of the control devices may “not acknowledge” (or “NACK”) that the control device received a “good message”, i.e., the control device experienced an error during the receipt of the digital message 600. For example, the control device may transmit a NACK character to report that the received digital message 600 has a bad checksum. To transmit a NACK character, the control devices preferably transmit a NACK break character during the NACK period. Following the HPR period, the time slot of the transmitting device is repeated to allow the transmitting device to re-transmit the last message if a NACK is detected during the NACK period.
Following the NACK period is the HPR period, which is also 240 μsec in length. The control devices are operable to report that the control devices have a high-priority event to transmit by transmitting HPR break characters during the HPR time.
Upon receipt of the HPR break character, the control devices on the communication link 114 are operable to enter a high-priority mode of operation, in which the control devices suspend the transmission of regular-priority digital messages for one timing cycle. Accordingly, the time slots pass without any control devices transmitting a regular-priority message until the time slot of a control device having a high-priority event to report arrives. Since the time slots are much shorter in length than the digital messages, the time slots pass quickly when the communication link 114 is in the high-priority mode of operation and the transmission of regular-priority digital messages is suspended. Thus, the time slot of a control device having a high-priority event to report is quickly reached in the high-priority mode. After a high-priority message is transmitted, any control devices that still have a high-priority event to transmit are operable to transmit an HPR break character during the HPR period.
The timing procedure begins at step 702, for example, at startup (i.e., power up) of the controller 150′. First, the controller 150′ waits at step 704 to detect a rising edge of a stop character of a message transmitted on the communication link 114. When the controller 150′ receives a digital message and detects a rising edge of a stop character at step 704, the controller resets and starts the timer at step 706 and determines the present slot number from the received digital message at step 708.
The controller 150′ waits at step 710 until the present time slot is complete, i.e., 300 μsec have expired since the present time slot began. When the present time slot is complete at step 710, the controller 150′ increments the present slot number at step 712, for example, from time slot 3 to time slot 4. At step 714, if the present time slot is not the time slot in which the controller 150′ is operable to transmit a digital message, the controller 150′ determines if a digital message has been received at step 716. If not, the timing procedure 700 loops around to wait for the end of the present time slot at step 710.
If a digital message has been received at step 716, the controller 150′ executes a receive (RX) routine 800.
If the received digital message does not contain a good checksum at step 818, the controller 150′ transmits a NACK break character at step 820 during the NACK period at the end of the digital message to signal that the digital message should be re-transmitted. Otherwise, the controller 150′ simply waits during the NACK period for the HPR period at step 822.
If the controller 150′ has a high-priority message to transmit at step 824, the controller 150′ transmits an HPR break character during the HPR period at step 826 and sets the HPR flag at step 828 before exiting the receive routine 800. If the controller 150′ does not have a high-priority message at step 824, but the controller 150′ detects an HPR break character during the HPR period at step 830, the controller 150′ sets the HPR flag at step 826 and exits the receive routine 800. If the controller 150′ does not detect an HPR break character at step 830, the controller 150′ clears the HPR break flag at step 832 and the receive routine 800 exits. Referring back to
If the HPR flag is set at step 716, the communication link 114 is in the high-priority mode of operation and one of the control devices has a high-priority message to transmit. If the controller 150′ has a high-priority message to transmit at step 718, the controller 150′ loads the hig-priority message into a transmit (TX) buffer at step 720. The controller 150′ then executes a transmit (TX) routine 900 (as shown in
If the controller 150′ detects a NACK break character on the communication link 114 at step 918, then at least one of the control devices on the communication link did not correctly receive the digital message transmitted at step 912. Accordingly, the controller 150′ sets the NACK flag at step 920, such that the controller 150′ is operable to re-transmit the digital message in the TX buffer. If the controller 150′ does not receive a NACK break character at step 918, the controller simply waits for the HPR time period at step 922.
If the controller 150′ has a high-priority message to transmit at step 924, the controller transmits an HPR break character on the communication link 114 at step 926 and sets the HPR flag at step 928. If the controller 150′ does not have a high-priority message to transmit at step 924, but detects an HPR break character on the communication link 114 at step 930, the controller 150′ sets the HPR flag at step 928. Otherwise, the controller 150′ simply clears the HPR flag at step 932 and transmitting procedure 900 exits.
Referring back to
After executing the transmit procedure 900, the controller 150′ waits for the end of the present time period at step 726. If the NACK flag is set at step 728 and the NACK counter is less than five at step 730, the controller 150′ increments the NACK counter at step 732. The controller 150′ then loads the previous message into the TX buffer at step 734 and re-transmits the message using the transmit routine 900. If the NACK flag is not set at step 728 or the NACK counter is not less than five at step 730, the controller 150′ clears the NACK counter at step 736 and the procedure 700 loops around to wait for the end of the present time slot at step 710.
While the protocol of the present invention has been described with reference to a wired communication link, the fundamentals of the method of the present invention could also be applied to another type of communication link including a wireless communication link, such as, for example, a radio-frequency (RF) or an infrared (IR) communication link.
Although the present invention has been described in relation to particular embodiments thereof, many other variations and modifications and other uses will become apparent to those skilled in the art. It is preferred, therefore, that the present invention be limited not by the specific disclosure herein, but only by the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
3425027 | Patterson et al. | Jan 1969 | A |
3444521 | Breese | May 1969 | A |
3689887 | LaFalce | Sep 1972 | A |
3806872 | Odom | Apr 1974 | A |
3818447 | Craft | Jun 1974 | A |
3863220 | Osawa | Jan 1975 | A |
3950728 | Etchison et al. | Apr 1976 | A |
3985962 | Jones | Oct 1976 | A |
4500987 | Hasegawa | Feb 1985 | A |
4829297 | Ilg et al. | May 1989 | A |
4926313 | Byers et al. | May 1990 | A |
5191265 | D'Aleo et al. | Mar 1993 | A |
5463286 | D'Aleo et al. | Oct 1995 | A |
5530322 | Ference et al. | Jun 1996 | A |
5631906 | Liu | May 1997 | A |
5642101 | Stirk | Jun 1997 | A |
5736965 | Mosebrook et al. | Apr 1998 | A |
5838226 | Houggy et al. | Nov 1998 | A |
5848054 | Mosebrook et al. | Dec 1998 | A |
5905442 | Mosebrook et al. | May 1999 | A |
5949200 | Ference et al. | Sep 1999 | A |
5982103 | Mosebrook et al. | Nov 1999 | A |
5990635 | Ference et al. | Nov 1999 | A |
6002669 | White | Dec 1999 | A |
6046550 | Ference et al. | Apr 2000 | A |
6233645 | Chrysos et al. | May 2001 | B1 |
6331756 | Belliveau | Dec 2001 | B1 |
6388399 | Eckel et al. | May 2002 | B1 |
6392368 | Deller et al. | May 2002 | B1 |
6430640 | Lim | Aug 2002 | B1 |
6487457 | Hull et al. | Nov 2002 | B1 |
6519509 | Nierlich et al. | Feb 2003 | B1 |
6546435 | Yoshimura | Apr 2003 | B1 |
6653933 | Raschke et al. | Nov 2003 | B2 |
6658017 | Yamamoto et al. | Dec 2003 | B2 |
6687487 | Mosebrook et al. | Feb 2004 | B1 |
6803728 | Balasubramaniam et al. | Oct 2004 | B2 |
6813525 | Reid et al. | Nov 2004 | B2 |
6917167 | Courtney et al. | Jul 2005 | B2 |
6927547 | Walko, Jr. et al. | Aug 2005 | B2 |
6983783 | Carmen, Jr. et al. | Jan 2006 | B2 |
7085627 | Bamberger et al. | Aug 2006 | B2 |
7126291 | Kruse et al. | Oct 2006 | B2 |
7211968 | Adamson et al. | May 2007 | B2 |
7219141 | Bonasia et al. | May 2007 | B2 |
7307542 | Chandler et al. | Dec 2007 | B1 |
7309965 | Dowling et al. | Dec 2007 | B2 |
7394451 | Patten et al. | Jul 2008 | B1 |
7548552 | Shvodian et al. | Jun 2009 | B2 |
7558269 | Le Pennec et al. | Jul 2009 | B2 |
20020047628 | Morgan et al. | Apr 2002 | A1 |
20020049822 | Burkhardt et al. | Apr 2002 | A1 |
20020130768 | Che et al. | Sep 2002 | A1 |
20030057886 | Lys et al. | Mar 2003 | A1 |
20030132722 | Chansky et al. | Jul 2003 | A1 |
20030222603 | Mogliner et al. | Dec 2003 | A1 |
20040002792 | Hoffknecht | Jan 2004 | A1 |
20050280598 | Webb et al. | Dec 2005 | A1 |
20060273970 | Mosebrook et al. | Dec 2006 | A1 |
20060284734 | Newman, Jr. | Dec 2006 | A1 |
20070061050 | Hoffknecht | Mar 2007 | A1 |
20070161349 | Grushkevich | Jul 2007 | A1 |
20070165589 | Sakoda | Jul 2007 | A1 |
20080101224 | Khasnabish | May 2008 | A1 |
20080125057 | Nass | May 2008 | A1 |
20080163065 | Vartiainen et al. | Jul 2008 | A1 |
20080191837 | Stocker | Aug 2008 | A1 |
Number | Date | Country |
---|---|---|
2 345 998 | Jul 2000 | GB |
WO 03007665 | Jan 2003 | WO |
Number | Date | Country | |
---|---|---|---|
20080192767 A1 | Aug 2008 | US |