Information
-
Patent Grant
-
6803728
-
Patent Number
6,803,728
-
Date Filed
Monday, September 16, 200222 years ago
-
Date Issued
Tuesday, October 12, 200420 years ago
-
Inventors
-
Original Assignees
-
Examiners
Agents
- Drinker Biddle & Reath LLP
-
CPC
-
US Classifications
Field of Search
US
- 315 149
- 315 294
- 315 155
- 315 292
- 315 299
- 315 315
- 315 320
- 315 317
- 315 319
- 315 316
- 315 360
- 362 233
- 362 85
- 362 293
- 362 234
- 362 339
-
International Classifications
-
Abstract
A wireless control system for lighting or the like has a central processor that receives commands from keypads and other control devices, and sends commands to dimmers and other controlled devices. The central processor also receives status reports from the dimmers and sends updates to the keypads, in order to ensure that displays on the keypads are up to date.
Description
FIELD OF THE INVENTION
The invention relates to a system for control of devices, and especially to a system for wireless control of lighting.
BACKGROUND OF THE INVENTION
Systems for the control of lighting are known in which keypads, switches, or other controls, hereinbelow generally referred to as “event initiators” are operated by a user, the event initiators communicate to a central processor, and the central processor communicates to the various lighting control devices. One such system is the HomeWorks® Interactive™ lighting control system manufactured by Lutron Electronics Co., Inc. of Coopersburg, Pa., U.S.A. The HomeWorks® Interactive™ system is designed to operate primarily with hard-wired connections between the various components of the system.
Lighting control systems using radio communication between separated components are also known. One such system is the RadioRA™ lighting control system manufactured by Lutron Electronics Co., Inc. Wireless systems are quicker and easier to install and reconfigure than hard wired systems. However, the radio frequency power and bandwidth available are usually limited by both regulatory and practical considerations. The frequency spectrum available is also used by many other systems. For example, the U.S. Federal Communications Commission allows low power, intermittent transmissions over a wide range of frequencies, including not only this sort of wireless control system, but also security systems, garage door closers, and the like. However, a large percentage of the range of frequencies is used by licensed operators, allowing only a small percentage of the range for use by unlicensed operators. Domestic lighting control systems need to be able to operate unlicensed, and therefore in the small percentage of unlicensed operator space.
Within that small space, interference among operators further limits the range of available frequencies at any given location. Because of the possibility of interference, and the need to operate at low power levels, it is also highly desirable to assess the quality of radio communications between devices within a wireless lighting control system. A measure of the quality of radio frequency communications is the probability of receiving a valid signal. Methods of assessing radio communications quality include measuring bit error rate, measuring ambient noise levels, and measuring the received signal strength of an intended signal, among others.
It is therefore an object of the present invention to provide improved control systems, and methods of installing and operating such control systems, that are especially suited to the wireless control of lighting installations, and to provide lighting installations equipped with such control systems.
BRIEF DESCRIPTIONS OF THE INVENTION
In one aspect, the invention provides a method of remote control of devices, comprising: detecting operation of at least one control by a user; predicting whether the event commanded by said operation of said at least one control will result in a change of state of a display; updating said display if the predicted state of said display differs from the state of said display before said operation of at least one control; transmitting a command indicative of said operation of said at least one control; receiving a response indicative of an event that actually occurred in response to said transmitted command; determining a correct state of said display; and updating said display if said correct state of said display differs from the state of said display as updated on the basis of said prediction.
In another aspect, the invention provides an event initiator that comprises:
at least one control operable by a user; a display; and a transmitter and receiver for sending commands and receiving responses; and wherein said event initiator is adapted to: detect operation of at least one control by a user; predict whether said operation of said at least one control will result in a change of state of said display; update said display if the predicted state of said display differs from the state of said display before said operation of at least one control; transmit a command indicative of said operation of said at least one control; receive a response indicative of an event that actually occurs in response to said transmitted command; and update said display if a state of said display correct in view of said response differs from the state of said display as updated on the basis of said prediction.
In another aspect, the invention provides an event initiator for a wireless lighting control system, comprising: at least one control operable by a user; a transmitter for sending commands to another unit within the system in response to operation of said at least one control; and a memory storing a control model that relates operations of said control to commands sent. The control model identifies operations of the control that denote valid commands, and associates a transmissible command with each identified operation.
In another aspect, the invention provides a lighting control system comprising at least event initiators having controls operable by a user and devices controlled by said event initiators, wherein: the event initiators and controlled devices comprise parts of a system database; the database part within each event initiator maps operations of controls by a user to commands transmissible from such event initiator to said controlled devices; the database part within each controlled device maps commands received from an event initiator to actions of such device; and the transmissible commands contain less data than is necessary to describe completely the operations of controls or the actions of devices.
An event initiator for a wireless lighting control system that comprises a plurality of sub-nets each operating on a different radio channel, the event initiator comprising: a database of said channels; and a transmitter and receiver capable of operating on any of said channels. The event initiator is arranged, upon activation, to search through channels in its database for an active sub-net of the system with which it can communicate.
In another aspect, the invention provides a method of assessing the quality of radio communications within a wireless lighting control system, the wireless lighting control system comprising a plurality of wireless transmitter/receivers, comprising the steps of: transmitting a signal from one wireless transmitter/receiver within the system; causing other wireless transmitter/receivers within the system to measure the strength of the signal they receive; and compiling a record of measured signal strengths.
In another aspect, the invention provides a method of selecting an operating channel for a radio frequency system, comprising the steps of: tentatively selecting a first channel; communicating on a second channel while determining whether the tentatively selected channel is suitable for communication; if the tentatively selected channel is found to be unsuitable, tentatively selecting a different channel, and repeating said steps of communicating, and determining; and when a tentatively selected channel is found to be suitable, starting to communicate on that channel as the operating channel.
In another aspect, the invention provides a method of selecting an operating channel for a radio frequency system, comprising the steps of: tentatively selecting a first channel; communicating on said tentatively selected first channel, while determining whether said tentatively selected first channel is suitable for communication; if said tentatively selected first channel is found to be unsuitable, tentatively selecting a different channel, and repeating said steps of communicating, and determining; and when a tentatively selected channel is found to be suitable, starting to communicate on that channel as the operating channel.
In another aspect, the invention provides a method of selecting an operating channel for a radio frequency system, comprising the steps of: providing a plurality of devices capable of communicating on a plurality of channels; tentatively selecting a first channel; causing the devices to communicate on a second channel; on the second channel, announcing the tentatively selected channel to the devices; switching the devices to the announced channel; by the devices, detecting properties of the tentatively selected channel; reporting back the results of such detection from the devices on the second channel; from such results, determining whether the tentatively selected channel is suitable for communication; if the tentatively selected channel is found to be unsuitable, tentatively selecting a different channel, and repeating said steps of announcing, switching, detecting, reporting, and determining; and when a tentatively selected channel is found to be suitable, starting to communicate on that channel as the operating channel.
In another aspect, the invention provides a method of assessing the quality of an operating channel for a wireless lighting control system that has a plurality of transmitting and receiving devices, comprising the steps of: by the devices, detecting properties of the selected channel including at least one property selected from: an ambient noise level on the selected channel at the location of each device; and the presence or absence of a contending system using the same channel within radio range of any device; and determining from the detected properties whether the channel is suitable for communication.
In another aspect, the invention provides a method of operating a wireless lighting control system, comprising the steps of: receiving at an event initiator a command from a user; transmitting over a wireless link a command corresponding to the command; receiving a transmitted command at a lighting device controller; and altering the state of a lighting device, by the controller, within 300 ms after the command is received at the event initiator.
A method of operating a wireless lighting control system, comprising the steps of: receiving at an event initiator a command from a user; transmitting over a wireless link a command corresponding to the command; receiving a transmitted command at a lighting device controller; altering the state of a lighting device, by the controller; and displaying at the event initiator, within 1.5 s after the command is received at the event initiator, an indication of the state of said lighting device after said altering step.
In another aspect, the invention provides a method of operating a wireless lighting control system that comprises a central controller and a plurality of remote devices that are in communication over a wireless link with said central controller and are programmed with an operating system, the method comprising: uploading an operating system to said remote devices by wireless communication.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1
is a schematic view of a wireless control system.
FIGS. 2
to
7
are flowcharts illustrating the setup, testing, and operation of the control system of FIG.
1
.
FIGS. 8
to
10
are diagrams of signal interchanges within the lighting control system of FIG.
1
.
FIG. 11
is a flowchart illustrating a method of uploading an operating system and a database in a lighting control system of the invention.
DETAILED DESCRIPTION OF THE DRAWINGS
Referring to the drawings, and initially to
FIG. 1
, one form of lighting control system in accordance with the invention is indicated generally by the reference numeral
10
. The system comprises central processors
12
, which are linked together by communications wiring
14
. (A wireless link may be used instead.) Each central processor
12
has a wireless transmitter/receiver
15
with an antenna
16
. The wireless transmitters/receivers
15
are preferably radio transmitters/receivers operating on a frequency approved for the operation of devices of this sort by the regulatory authorities of the place where the system
10
is to be operated. Preferably, each transmitter/receiver is capable of being tuned to any of a block of frequency channels, and each central processor
12
operates on a different channel. In the U.S.A., 60 channels, each 100 kHz wide, are available.
The system
10
further comprises repeaters
18
, each of which is equipped with a transmitter/receiver
19
with an antenna
20
. In a manner that will be explained below, each repeater
18
is tuned to the channel used by a central processor
12
with which that repeater is associated. In normal operation, the repeaters
18
merely receive and retransmit signals, extending the effective range of communication from a central processor
12
beyond the reach of its own transmitter/receiver
15
. Where appropriate, one repeater
18
may be in communication with another repeater
18
, providing a still greater extension of range.
The system further comprises lamps
22
, controlled by device controllers
24
, each of which has a wireless transmitter/receiver
25
with an antenna
26
. The system may also comprise devices other than lamps, for example, power operated window blinds
22
a
, a sound system
22
b
, or the like. Instead of, or in addition to, controlling lights, the system may be another system, such as a home automation or security system. In a manner that will be explained below, each device controller
24
is tuned to the channel used by a central processor
12
with which that device is associated. Each device controller
24
may be in radio communication with the central processor
12
directly, or via a repeater
18
or a chain of repeaters. Each device controller
24
receives commands from its central processor
12
for the operation of its lamp
22
, and sends back to the central processor information on the actual operation of the controller and the controlled device.
The system further comprises keypads, switches, or other event initiators
28
, each of which comprises a wireless transmitter/receiver
29
with an antenna
30
and at least one control
32
that can be operated by a user of the system. Each event initiator
28
preferably also comprises a display
34
, which may be one or more light emitting diodes, a liquid crystal display, or any other suitable display. The display
34
may be visible or audible, or may work by touch, or even smell. In a manner that will be explained below, each event initiator
28
is tuned to the channel used by a central processor
12
with which that device is associated. Each event initiator
28
sends to its associated central processor
12
, either directly or via one or more repeaters
18
, user commands for the control of lamps
22
or other devices
22
a
,
22
b
, and receives from the central processor, and displays on the display
34
, information about the actual status of the controlled devices.
Although in the interests of simplicity the device controllers
24
are described as separate from the event initiators
28
and displays
34
, a device controller may also include a display
34
, showing the status either of its own device
22
or of other devices, and or an event initiating control
32
either for its own device
22
or for other devices.
Each component of the system may be provided with electrical power from ordinary electrical outlets or wiring at its location, independently of any other device. Because the electrical wiring is not being used as a communication path, but merely as a source of power, there is no need to consider whether or not the different components are on power supply circuits that are isolated from one another. Except in the case of wired links
14
between different processors
12
, the use of wireless communications also removes the need to prevent antenna loops from being formed between the power and data circuits between two components.
It will be appreciated that the number of each component, and the kinds of event initiator
28
and controlled device
22
,
22
a
,
22
b
will vary, depending on the configuration of the individual system. In particular, a small system may have only a single central processor
12
and no repeaters
18
. A system that has both a large number of controlled devices and a large spatial extent may have several central processors
12
and numerous repeaters
18
. Provided that each central processor
12
operates on a different radio channel, they do not need to be spatially separate, but can control different aspects of the function of the system in a single area.
Referring now to
FIG. 2
, when the system is initially installed, at step
50
a central processor
12
is first installed and powered up. At step
51
, the central processor
12
selects at random a sub-net address. The sub-net address is an identifying code that will form part of every transmission by that central processor
12
or by any of the repeaters
18
, device controllers
24
, or event initiators
28
that are in wireless communication with that central processor, either directly or through one or more repeaters. The use of a sub-net address greatly reduces the risk of a transmission from outside the system being erroneously accepted as a message by any component within the system.
Next, the quality of radio communications within the wireless lighting control system is assessed. At step
52
, the central processor
12
selects at random one of the available radio channels. At step
54
, the central processor
12
listens to the selected channel, and at step
56
the central processor decides whether the ambient noise on that channel is unacceptably high. If the received signal strength is greater than a first threshold, the central processor rejects the channel as unusable, and returns to step
52
to select a different channel. If the received signal strength is less than the first threshold but greater than a second, lower threshold, the central processor
12
rejects the channel as usable but unsatisfactory, and returns to step
52
to select a different channel. The central processor maintains a list of rejected channels, to ensure that it does not inadvertently select a channel that has been selected and rejected in a previous iteration.
If the received signal strength is less than the second threshold, the central processor proceeds to step
58
, and broadcasts on the selected channel a “who is there” message. Every central processor
12
in accordance with this embodiment is programmed to respond to such a message by transmitting a response including its sub-net address. This test thus reveals the presence of another similar, contending control system operating on the same channel within the range of the transmitter/receiver
15
. At step
60
, the central processor
12
checks whether a response has been received and, if it has, rejects the channel as unusable and rejects every sub-net address given by a contending system. At step
61
, the central processor
12
checks whether the sub-net address actually being used by the central processor is the same as a rejected sub-net address. If so, the central processor returns to step
51
and selects a new sub-net address. Whether or not a new sub-net address has been chosen, if a response was received from a contending system, the central processor then goes to step
52
to select a new channel.
If no contending system is detected, the channel in question is tentatively selected, and at step
62
any repeaters
18
in the system are installed and activated. If there are no repeaters, the tentatively selected channel is selected, and the process jumps to step
70
. At step
64
, the central processor
12
informs the repeaters of the channel and sub-net address that have been tentatively selected. In a first embodiment, this is done using a “default” channel that is set into each unit when it is manufactured. This embodiment is the simplest to implement, but if the default channel is completely unusable then every unit must be manually reset to a different default channel, which is tedious for the installer. If a default channel is used, then the central processor is programmed not to select that channel for other purposes.
At step
66
, each repeater
18
tests the tentatively selected channel for ambient signal strength and for responses to the “who is there” signal. Of course, at this stage, the central processor
12
and the repeaters
18
are programmed not to respond to each other's “who is there” signals. After a preset delay, for example, 10 seconds, at step
67
all units switch back to the default channel, and the repeaters
18
report back to the central processor
12
the ambient signal strength and the presence and sub-net address of any contending system. This step extends the test range of the system to detect sources of ambient interference or contending systems that are within range of the outermost repeaters
18
, but are not within range of the central processor
12
.
At step
68
, the central processor
12
decides whether to accept or reject the channel, using the same criteria as in steps
54
to
60
. If the channel is rejected, at step
68
A, the processor checks whether a contending system with the same sub-net address has been detected and, if so, a new sub-net address is chosen at step
69
. If the channel is rejected, the central processor tentatively chooses a new channel at step
69
A, and returns step
64
. It will be understood that in any subsequent iterations of steps
64
-
69
A, the central processor
12
and the repeaters
18
will carry out the tests of steps
54
to
60
simultaneously.
It will be appreciated that, in the worst case, the above process may result in every channel being rejected. In that case, the system returns to step
64
, and repeats the process using channels previously rejected as usable but unsatisfactory. Preference is given to channels with no contending system and a reasonably low ambient received signal strength. However, a contending system, especially one with a faint signal, can be tolerated as long as the two systems have different sub-net addresses.
Once a channel is selected in step
68
, at step
70
the device controllers
24
and event initiators
28
are activated. In step
72
, the central processor, on the default channel, announces the selected channel and the sub-net address. At step
74
, each device acknowledges those instructions on the default channel. When the processor
12
confirms that every acknowledgement has been received, at step
76
every device switches to the selected channel. If the central processor fails to receive an acknowledgment from a specific unit
24
or
28
, the processor may loop back to step
72
, and make a further attempt to command that unit to switch. Instead, or in addition, the processor may proceed to step
78
, in case the unit
24
or
28
did receive and act on the command to change channels, and only the acknowledgment was lost.
As a confirmatory measure, at step
78
the central processor polls every device on the selected channel to confirm that it is in communication. If a device fails to respond, this is probably best treated as a service fault to be diagnosed and remedied, rather than as part of the setup process. The central processor
12
therefore merely emits an error report to the installer, and does not itself take any remedial action.
At this stage, each unit needs to be assigned a unique address within the system, or at least within the sub-net, that can be used to address commands to that unit. It would be possible to use absolutely unique addresses, built into each unit at the factory. However, to reduce the length of the addresses, and thus the amount of network traffic, it may be preferred to assign to each unit a short address that is unique only within the system. Every subsequent signal will then contain the sub-net address, the address of the initiating and/or destination unit, and the substantive content of the message.
At step
80
, if there are more central processors
12
, the next processor
12
is activated, and the setup process resumes from step
50
. However, the new processor
12
is preferably provided with the lists of unusable and unsatisfactory channels and sub-net addresses compiled by the previous processor, and initially avoids those selections. The new processor
12
also avoids the channels and sub-net addresses already in use by sub-nets in the system.
Although the installation process has been described above as being carried out by the central processor
12
, it involves considerable processing work that is not required during normal operation of the control system. It may therefore be preferred to conduct the installation process under the control of a program running on a personal computer
90
that is connected to the central processor
12
for the duration of the installation process. This has the additional advantage that substantial databases, for example of the characteristics of the various types of component that can be included in the system, can be made available to the installer, and that data files created during the installation, for example, of the results of the channel and address selection routines described above, and the configuration of the system as installed, can be stored as ordinary computer-readable data files for future reference. Such stored data files are a useful starting point if an additional sub-net is added to the system at a later date, or if the system has to be reinitialized because of a contending system or source of ambient noise that was not discovered, or was not present, at the time of the original installation.
In a second embodiment, rather than the repeaters
18
, event initiators
28
, and device controllers
28
having a factory-defined default channel, when the repeaters
18
, the event initiators
28
, and the device controllers
24
, are activated, they automatically scan the allowable channels for an activation signal that the central processor transmits on a tentatively selected channel, which it has selected using the same methodology as steps
52
through
60
. The sub-net address is selected in a similar manner to that as described in connection with the description of FIG.
2
. In a third embodiment, which is a modification of the first embodiment, preferably the central processor
12
tentatively selects two channels, and the activation signal informs the repeaters
18
of what the second channel is. One of the two channels is then used as the “default” channel and the other as the “tentatively selected” channel.
Referring now to
FIG. 3
, once the initial installation is complete, or as part of a later diagnostic test, the installer may wish to assess the quality of radio communications by surveying the signal strength of the various communications links in the system. The survey may cover any one or more of the classes of links: from a central processor
12
to its repeaters
18
; from the repeaters
18
to the central processor; from one repeater to another; from the central processor and/or repeaters to the event initiators
28
and device controllers
24
; from the event initiators and device controllers to the central processor and/or repeaters; or from the central processor to the event initiators and device controllers or vice versa, treating the repeaters transparently. The first four of those categories test the reliability of individual wireless links, while the last may reveal problems in the operation of a repeater. It is preferred to survey each wireless link separately in each direction, because the results may be different, especially where a problem is caused by an obstruction or a source of ambient noise close to one end of the link.
By way of example,
FIG. 3
shows a method for generating a received signal strength indication (RSSI) Map for signals received by the controlled devices
24
and event initiators
28
from the central processor
12
and repeaters
18
.
In step
100
, the central processor
12
sends a “Measure RSSI and report back” command. This command consists of the actual command, followed by a standard signal that the receiving units can easily measure the signal strength of. The repeaters
18
relay the actual command to their units
24
and
28
, but do not transmit the standard signal. In step
102
, each unit receiving this command measures and stores the RSSI of the standard signal sent out in Step
100
. Thus, each unit is measuring the signal received directly from the central processor's transmitter
15
.
In step
104
, each unit that received the command acknowledges and reports the RSSI value that it measured in step
102
. The central processor
12
, or the attached computer
90
, records these results. A value of 0 may be entered if no reply is received from a particular unit. A 0 value is not necessarily a problem, because a unit that does not receive signals directly from the central processor
12
may later be found to receive a strong signal from one or more repeaters.
In step
106
, the central processor
12
sends a command to “Measure RSSI values from Repeater
1
”. At step
110
, every repeater
18
, device controller
24
, or event initiator
28
receiving the signal from repeater
1
records its strength, and at step
111
all of those units report back the RSSI value to the central processor
12
. Provided that signals transmitted by repeaters
18
include a header identifying the repeater that sent the signal, all repeaters may be allowed to repeat the whole RSSI command as if it were a normal operating signal. Each receiving unit then receives the standard signal sent out from every repeater that it can hear, but responds by recording the strength only of the signal received directly from the specified repeater.
To assist the person conducting the test, where a unit measuring the RSSI value has a suitable display, it may provide an immediate local readout of the RSSI value. For example, a keypad
28
with an LED may cause the LED to flash at a rate indicative of the RSSI value.
In step
112
, the central processor checks whether there are more repeaters to test. If so, the process loops back to step
106
, and the central processor sends a command to measure RSSI values from the next repeater.
Once all of the repeaters
18
have been tested, in step
113
the central processor
12
decides whether to repeat the tests. For a quick assessment of the state of the system, a single series of tests, or an average of two measurements, may be sufficient. For a more precise result, the central processor may return to step
100
and repeat the process two or more times. Once the testing is completed, at step
114
the central processor generates a map or record of signal strengths. This may be a list of links or logical map in tabular form or, if the attached computer has a graphical user interface and a physical map of the system configuration, may display the physical location of strong and weak links. RSSI values greater than a pre-determined threshold may be considered good, implying the path loss from the central processor
12
or nearest repeater
18
to a particular unit is low enough for the link to be considered reliable, not marginal. If the results are based on more than one iteration of steps
100
to
112
, the results presented may be a simple average of the measured results, or may also indicate the degree of variation between different iterations.
The central processor may generate a report to the installer listing all reliable links and/or all unreliable links after comparing all RSSI's to a predetermined threshold, or it may give the actual RSSI values and let the installer decide what is acceptable. This report gives the installer practical information regarding repeater placement in a system of devices, repeaters, and central processors. Potential weak links can be identified. For example, a device
24
or
28
may have no, or only one, reliable link to a repeater
18
and, if so, the installer may wish to add a repeater or move an existing repeater. The installer can set his own standards for the number of reliable links.
The Map generated by the process of steps
100
to
114
gives RSSI values based on the one way path loss from the central processor
12
and the repeaters
18
to the devices
24
and
28
. RSSI values to obtain path loss values in the other direction (from the devices to the repeaters and central processor) can be generated using a similar method, by sending out a command that directs each device to transmit the standard signal, and measuring the RSSI of that signal at the central processor and at each repeater. The results for each device
24
or
28
may be measured and reported back to the central processor
12
separately or, if the repeaters have sufficient local memory, the system may test every device in a continuous sequence, and each repeater may then report back to the central processor a single list of results.
RSSI values between other pairs of system components, in either or both directions, can be generated analogously.
Referring to
FIG. 4
, as a further test of system integrity, in step
120
the central processor may broadcast a “who is there” message to which all units are programmed to respond in step
122
. Each unit may identify itself either by including a unit address as part of its response, or by responding in a time slot that is determined by the unit address. In step
124
, the central processor
12
then compares the responses with a database of the system, and reports to the user. Units that respond and are in the database do not suggest a problem. If in step
125
the processor
12
identifies units that are in the database but do not respond, then in step
126
the processor issues a report suggesting either a fault in the unit or a weak communication link. If in step
127
the processor
12
identifies units that respond but are not in the database, then in step
128
the processor issues a report suggesting either an error in the database or a contending system that was not detected in the installation process of FIG.
2
.
Referring to
FIG. 5
, as a further test of system integrity, in step
130
the central processor may issue a command to a particular device, or to all devices, to produce a distinctive indication. For example, in step
132
an event initiator
28
that has an LED indicator
34
may respond by flashing the LED continuously. For example, a lamp controller
24
may respond by flashing its lamp
22
. Other types of unit may use other forms of indication. The indication merely needs to be distinctive and within the powers of the unit in question. In most cases, the indication is preferably reasonably conspicuous, but this may depend on circumstances. In step
134
an operator then goes to the device in question. In step
136
, if it is not flashing, the operator deduces in step
137
that the device did not receive the “flash” command from the central processor. If the device is flashing, in step
138
the operator operates a control on the device. In step
139
, the device
24
or
28
then signals the central processor
12
, which replies in step
140
with an instruction to the device to stop flashing. The central processor
12
may also emit a signal, for example a loud beep, in step
141
, when it receives the signal from the device. Thus, if in step
142
the operator does not hear the beep, the operator may infer in step
143
a failure in communication from the device to the central processor. If the operator hears the beep but the device does not stop flashing in step
144
, the operator may infer in step
145
a failure in communication
Once testing of the particular unit is completed, by failure in step
137
,
143
, or
145
or by success in step
144
, the operator considers in step
146
whether there are more units to test. If so, the process returns to step
130
, where the central processor either sends the “flash” command to the next unit, or maintains an “all units flash” command previously issued.
Instead of sending a single “flash” command that commands units to flash until the command is revoked, in steps
147
and
148
the central processor
12
may repeat the “flash” command to a device, at an interval T
0
, for example, every 5 seconds. In step
149
the device
28
then counts the time since the last “flash” command was received, and in step
150
the device stops flashing if no “flash” command is received within a preset period T
1
, which is longer than the time between commands sent in step
148
. Thus, if the device
28
is moved outside the range of the nearest transmitter
15
or
19
, it will stop flashing after the time period preset for step
149
. If the device
28
is brought back into the range of a transmitter
15
or
19
, it will start flashing again at step
151
when the next “flash” signal is received. This function is useful when, for example, repositioning repeaters. Both the range from the central processor
12
to the repeater
18
being moved and the range from the repeater to its client devices
24
and
28
can then be monitored. Where the device is, for example, a hand-held, battery powered event initiator
28
, the device may be used as a simple signal-strength gauge to detect the boundaries of the area reached by the transmissions from the central processor.
The process of steps
147
-
151
may be used with any movable component of the system that is capable of producing a perceptible response to the “flash” command, but is most practical with hand-held, battery operated units that can be moved freely.
The “flash” command of steps
130
and
148
, like the standard signal of the “measure RSSI” command in steps
100
and
108
of
FIG. 3
, may be emitted from the central processor
12
only, or from a specific repeater
18
only, if it is desired to examine the radio coverage of the specific transmitter, rather than that of the sub-net as a whole.
Referring to
FIG. 6
, portable devices, such as handheld event initiators
28
, are preferably arranged to enter a “sleep” mode in step
152
, in order to conserve battery power, when it is determined in steps
153
to
156
that the control has not received a command for a predetermined period T
2
. For the purpose of step
153
, “command” includes both radio signals received from the central processor
12
or other units within the system, and button presses or other operations by a user of the handheld device
28
. In the “sleep” mode, the device does not receive radio signals from the rest of the system. However, a handheld device may be moved while it is asleep. In particular, the device may be moved out of the range of the transmitter
15
or
19
with which it was previously in communication. Each handheld or otherwise reasonably portable device
24
or
28
is therefore programmed with a list of the radio channels and sub-net addresses for central processors
12
in the system to which it belongs. Where two or more sub-nets handle different functions in the same geographical region, duplicates may be omitted from the list.
When the handheld device
28
is operated in step
157
, it “wakes up” in step
158
. It then first sends out in step
159
a “who is there” signal addressed to the central processor
12
and repeaters
18
on the sub-net on which it was last active. If it receives an acknowledgement in step
160
, it then transmits in step
162
a signal conveying the command corresponding to the user operation in step
157
, waits for an acknowledgement in step
164
, and returns to steps
153
-
156
to await further activity.
If in step
160
the handheld device
28
does not receive an acknowledgement, then it assumes that it is no longer in the area of the sub-net in question, and in step
166
the unit selects a different sub-net. Depending on how sophisticated the device
28
is, it may maintain a dynamic list of the most frequently or most recently used sub-nets, it may scan the allowed channels and start with the one having the strongest signals, or it may follow the order in which the channels are stored in its internal list. The unit then loops to step
159
, and attempts to communicate on the newly-selected sub-net.
If in step
168
the device determines that it has tried every sub-net in its system without establishing communication, it assumes that it has been moved entirely outside its territory. In step
170
, the device displays a failure signal, and then returns to step
152
and enters the “sleep” mode.
It will be appreciated that, where a portable event initiator
28
is moved around a large system its function may become ambiguous. For example, if the event initiator
28
controls a window blind
22
a
, it may always control the blinds on a specific window or group of windows. Instead, it may control the blinds on that window or group of windows if it is physically close to that window or group of windows, and otherwise do nothing. In either of those cases, the unit
28
is preferably conspicuously labeled to identify which windows it applies to. Instead, the event initiator may control the window blinds nearest to wherever it happens to be. This is only practical if each transmitter
15
or
19
covers a very small area, so that the physical location of the unit
28
can be determined precisely.
It has been found experimentally that, where an event initiator
28
has a display
34
offering feedback to the user on the effect of operating a control
32
, the display
34
should preferably respond within approximately 0.5 and 1.5 seconds after the control is operated. If the response time is less than 0.5 seconds, the user will not notice any improvement in responsiveness. If the response time is greater than 1.5 seconds, the user stops paying attention and does not benefit from the feedback when it is displayed. With a wired system, it has been proposed for the display
34
simply to show the command that has been entered on the control
32
, which can be done immediately, and to assume that is correct.
With a wireless system, on the other hand, there is a material risk that the command from the control
32
will not be correctly received and implemented by the device controller
24
. It is therefore prudent for the event initiator
28
to display the actual status of the controlled device
22
. However, confirmation of that status may not be available within 1.5 seconds after the control
32
is operated, especially if there is a long chain of repeaters involved, or if the level of radio traffic causes delay in transmitting messages. Therefore, the event initiator
28
maintains a memory of the status of the controlled device
22
.
Referring to
FIG. 7
, if in step
180
the user operates the control
32
, in step
181
the event initiator determines whether it is necessary to update the display
34
. If so, at step
182
the event initiator may immediately update the display
34
to show the effect of the command just given by the user. If there is no change in the display because of step
182
, then in step
183
a transient signal may be displayed to confirm that a button press has been registered. For example, the control
32
may be a button that cycles a lamp
22
through OFF and five different dimming levels, and the display
34
may be an LED that is lit unless the lamp
22
is OFF. Then, if the event initiator
22
believes it is merely changing the dimming level of the lamp
22
, the LED
34
should stay on. In that case, the LED may be blinked off for a fraction of a second to show that a button press has been detected.
Instead of, or in addition to, step
182
, in step
184
the event initiator
28
may immediately request from the central processor
12
current information on the status of the device
22
. This status update may then be used in steps
185
and
186
to update the display
34
. This is particularly important if the event initiator
28
is movable, has a sleep mode, or is otherwise not in continuous communication with the central processor
12
. In those cases, the event initiator may be unaware of a change in the status of the controlled device
22
that was caused by another event initiator at a time when the first initiator was not receiving. It is also particularly important if the operation of the control
32
is ambiguous. For example, if pressing a button
32
toggles or cycles the status of the device
22
, and the display
34
, then the effect of pressing the button
32
will depend on the status of the device immediately before the button was pressed.
In step
187
, the event initiator
28
transmits to the central processor
12
the command corresponding to the user's operation of the control
32
. In step
188
, the central processor
12
acknowledges the signal from the event initiator
28
.
The status update process of steps
184
-
186
and the command and acknowledgment process of steps
187
-
188
are shown in parallel in
FIG. 7
, because either may come first. For example, if the event initiator
28
is portable, an update may be requested and obtained as part of the handshaking process in steps
159
and
160
of FIG.
6
. Instead, the update may be part of the acknowledgment message in step
188
, or an update may be separately requested and supplied at any convenient point.
In step
190
, the central processor then commands the device controller
24
to change the status of the device
22
. In step
192
, the device controller
24
does so, and monitors the device
22
to ensure that it is working correctly in its new status. In step
194
, the device controller
24
reports back to the central processor
12
. In step
196
, the central processor
12
updates its own record of the status of the device
22
, and in step
197
the central processor signals the current status to the event initiator
28
. Instead of one of the explicit update steps
184
and
197
, the event initiator
28
may be programmed to recognize, and at least partly understand, one of the signals between the central processor and the device controller
24
. In step
198
, the event initiator
28
updates its own memory of the status of the device
22
. In step
199
, the event controller
28
checks whether the display
34
needs to be changed. If so, it updates the display
34
in step
200
. If there is a change in the display
34
, and it is determined in step
201
that there has been a significant delay since the display was last updated in step
182
or step
186
, then in step
202
the event initiator may emit a beep or other attention-catching signal to alert the user to the change.
It will be understood that the event initiator
28
will usually have only a very oversimplified knowledge of the controlled device
22
, and status information received by the event initiator from the processor will be similarly simplified. For example, if the control
32
is a button, and the display
34
is a row of LEDs, the event initiator may simply cycle through the row of LEDs, advancing one step every time the button
32
is pressed. Any status update from the central processor then merely needs to tell the event initiator
28
where in the cycle it should be.
Because the radio channels used by the present system have very limited bandwidth, and because an entire sub-net shares a single channel, so that it will often be impossible for two messages to be transmitted simultaneously without interfering with one another, it is important to minimize the amount of radio traffic. In particular, it is useful to minimize prolonged continuous transmissions that occupy the radio channel.
Therefore, each event initiator
28
contains a memory in which is stored a “control model” of the intended operations of that event initiator. A control model is defined as a description of the behavior of a control system, including the expected next state of the control system, and what values it should output, if any, depending upon the current state of the system, and the values of any received inputs. A “button model” is one type of a control model, found, in this instance, in event initiators, typically having user actuatable buttons. The button model contains information on the intended operation of the event initiator in response to actuation of the buttons thereon, and in response to receipt of information signals received thereby. Corresponding information is stored in the memory of the central processor
12
. Thus, instead of transmitting a series of “button pressed” and “button released” signals, or continuous or rapidly repeated “button is down” signals, the event initiator can analyze the physical and logical operation of the button, and send more efficient signals.
If either a single or a double tap of the button is a valid command, if the button is pressed the event initiator may wait for a short period to see whether or not there is a second press, and then transmit either a “single tap” signal or a “double tap” signal. If a single tap is a valid command, but a double tap is not valid, the event initiator may transmit a “single tap” command as soon as the button is pressed and released once, and may ignore a second press immediately following.
It has been observed that if the light being controlled is visible to the user operating the control
32
, the user may become impatient if no response is perceived within a period as short as 300 ms. This time is shorter than the minimum required time mentioned above for response by the display
34
, because the user does not need to think consciously about the expected and actual results. This may present problems if, for example, the control
32
is a button that toggles a light on and off, and the impatient user presses the button again, thus reversing its toggle status. The user trying to turn the light on then turns it off again, or vice versa. If a control
32
is a toggle button, and the controlled device
22
is known to be slow to respond, the button model may transmit a first button press immediately, and ignore a second press of the button within the response period of the device
22
.
A button may be intended to be pressed, starting a slow change, say in dimming of a lamp or in the position of a blind, and held until the change reaches the desired level. In that case, for long changes the efficient use of the radio channel is to send a “button pressed” signal and a “button released” signal. This leaves the radio channel free for other traffic while the button is being held down. However, for a very slight change it may not be possible to send the “button released” signal quickly enough. Therefore, the optimum model may be to send an initial “button is down” signal. Then, if the button is released, the signal ends immediately, and that trailing edge is the effective signal to stop the change. This gives a precise response: first, because the event initiator
28
is already in possession of the radio channel, and does not need to wait for another transaction to finish; and second, because it is not necessary to send a message header before the operative part of the signal.
If the button
32
is held for more than a certain period, the event initiator
28
sends a “button stays down” signal and releases the radio channel. When the button is eventually released, the event initiator sends a separate “button released” signal. On a long change, the delay that may be experienced in sending and receiving the separate “button released” signal, and any resulting overshoot in the level being changed, is much less noticeable. It is still preferred to achieve a consistent response time no slower than 300 ms, to give reasonably accurate control of the final level of the blind or light and, if more than one blind or light is involved, to ensure that they all stop at approximately the same level.
If the control
32
is a slider, it may be sufficient to wait until it stops moving, and then transmit a single signal giving its final position. However, it may be necessary to transmit a series of progress signals so that the controlled device
22
can track the slider as the slider is moved. It may be appropriate to use the single signal for a sudden movement, and the series of signals for a slow, prolonged movement. The choice of which mode to use will likely depend not only on what the controlled device is, but also on where the device is. A user who is within the field of a lamp being dimmed is more likely to expect to see the lamp brightness change in real time as the user moves the dimmer slider.
Different buttons
32
on a single event initiator
28
can be set up to have different effects on the same controlled device. For example, one button may be configured always to turn on the lights to 100% every time it is pressed, while another button may toggle the lights between 100% and off with each button press. Likewise, the LEDs can be used to give the user different types of feedback. For example, one LED might be on if and only if the lights are all on at 100%, while another LED may be on whenever any of the lights are on, no matter the level.
The button model is preferably stored in a field-programmable but non-volatile memory on the event initiator
28
. This greatly simplifies manufacture and distribution, by allowing the installer to configure a standard event initiator to the requirements of a particular installation. Preferably, the memory is field-reprogrammable, to allow the event initiator to be reconfigured if the system is changed, or to be reassigned to a different function within the system.
The button configuration may allow a button to be configured at run-time by a user, giving the users flexibility in their programming and system layout, or may require special equipment and/or knowledge so that the system can be reconfigured only by a “super user” or a maintenance engineer.
Referring now also to
FIGS. 8 and 9
, in order to minimize the amount of radio traffic, the databases controlling the system are divided into three parts, held in the event initiators
28
, in the device controllers
24
, and in the central processor
12
.
As discussed above, the database in a keypad or other event initiator gives the keypad
28
enough intelligence to know what to send to the processor
12
in the form of actions by a user of the event initiator, for example, a button press or a release. User actions that do not cause events in the system would waste bandwidth, so should not be transmitted. User actions that do cause events should be transmitted in the most efficient form.
The keypad
28
also knows whether to expect a response back from the processor in the form of an acknowledgment. The acknowledgment can be re-used as, or supplemented by, an update of the keypad's status information to update the display
34
. The acknowledgment can also be used to indicate that the keypad
28
should repeat a command because it has not been clearly received, or to send to the keypad
28
a new command that the keypad may not know the definition of.
The dimmers and other device controllers
24
contain lists of scenes. A “preset scene” or “scene” is a pre-programmed setting of one or more device controllers
24
, and especially a coordinated setting of several device controllers
24
, for example, off, on, and dimmer settings for all of the lights in a room, to produce a coherent effect. For each scene, each device controller
24
knows what level of dimming or other state to set its controlled device
22
to, and may also know what rate of fade and what delay before the fade starts to use when activating that scene. It is then merely necessary to broadcast a single message commanding that a specified scene be activated. The single message can be received, understood, and implemented by every device controller
24
responsible for a device
22
involved in the scene in question. This minimizes the amount of data that needs to be sent to activate a scene, independently of how big the scene is, and independently of how great the changes from the previous state of the controlled devices are. If this is done, the device controllers
24
must, of course, be programmed to accept messages addressed to a “unit address” that indicates a scene command.
Each device controller
24
can also be directly controlled, with signal coding similar to the “button models” described above, so that a device
22
can be set to a status that is not part of a preset scene. After a change, each dimmer or other device controller
24
passes its current level back to the processor
12
, so that the processor knows the current state of all dimmers.
The processor
12
does not need to be aware of the actions caused by a button. It can simply run a predetermined script. However, it is preferred that the processor
12
maintain a record of the supposed current status of the entire sub-net. The processor
12
can then verify that the device controllers
24
are reporting the correct status, and that the event initiators
28
and any other display devices are showing the correct status. As mentioned above, this is especially important where a device controller
24
may be controlled by more than one event initiator
28
, and where the displays
34
are not necessarily all updated immediately when a change occurs.
In many cases, the processor can simply relay to a device controller
24
the button signals received from an event initiator
28
. However, some actions are conditional upon other inputs into the system, such as the time of day. For example, a “scene” may be defined to have different meanings at different times of day, or the response to a command may depend on the existing state of the system. Since the factors involved in these conditional decisions may be numerous and complex, having a central decision point makes for minimal communications. For complex models, the evaluation of what to do on a button press requires a lot of CPU power, and it is therefore economical to have a single, central CPU in the processor
12
that does all of the complex work.
Individual device controllers
24
may also be equipped with local controls
32
that enable the associated device
22
to be controlled directly. When that occurs, the dimmer
24
reports to the processor
12
, which updates its own records and determines whether the LEDs in the system are correctly set and transmits any necessary update signals.
Each processor
12
will listen to other processors in the system over the wired link
14
to receive signals that affect devices
22
and displays
34
on its own sub-net. For example, if a single scene involves two groups of lamps
22
that are on different sub-nets, and a button
32
is operated to select that scene, the processor
12
that receives the button press must relay to the other processor
12
the command to select that scene. If a display
34
on one sub-net indicates the status of devices
22
that are on another sub-net, the processor
12
responsible for the devices
22
must update the processor
12
responsible for the display
34
. If a portable event initiator
28
is in communication with a sub-net other than its own, then the processor
12
with which the event initiator is in communication must relay messages to and from the event initiator's “home” processor. In order to minimize the amount of data that has to be carried by the links
14
and handled by the processors
12
, each processor
12
will only pass information about its part of the system to the links
14
when it changes, and when the changes are relevant to the other sub-nets. This restraint makes very large systems possible without the data capacity of the links
14
, or the power of the processors
12
, becoming prohibitive.
Since the event caused by pressing a button
32
is usually related to the current state of an LED
34
, the processor
12
will usually have the most up to date information about the action that should be performed, and what the LEDs should show, on a button press. Having the action and the LED tied back to the processor
12
keeps things from getting out of synch.
The processor maintains a copy of the dimmer database showing what device
22
each controller
24
controls, and what commands are applicable to that device, so that the information can easily be extracted and changed by features that allow updating of scenes. This also allows for easy integration of third party devices that would communicate with the processors
12
via RS232 ports to receive commands and report their status. The processor can also originate commands to activate scenes or otherwise change the settings of the devices
22
. This could happen if the processor is running a pre-programmed sequence, including a “vacation” mode where the processor plays back actual changes in lighting recorded on a previous occasion, or if a time-clock causes a change in lighting to suit a different time of day.
Referring now to
FIG. 8
, in one example, when a button
32
(in this example, button
1
) on an event initiator
28
(in this example, keypad
1
) is pressed, a processor
207
in the keypad consults its stored button model
208
, which directs it to send a message
210
reporting “button
1
on keypad
1
pressed.” On receiving this message, the CPU
211
of the processor
12
consults its dimmer database
212
which, in the present status of the system, identifies a press of keypad
1
button
1
as a command to switch on preset scene
1
. The processor
12
therefore sends out a command
214
to turn on to preset scene
1
. A processor
215
in each dimmer
24
that receives the command
214
looks it up in its own internal dimmer map
216
, and converts the command into instructions to delay for a specific period, then change at a specific fade rate to a specific dimming level. Each dimmer
24
executes these instructions.
Each dimmer
24
, after completing the change, sends back a report
218
to the central processor
12
. The reports
218
convey information such as “dimmer
1
now at 100% of full brightness.” The reports
218
give absolute values, rather than merely acknowledging “command to switch to preset scene
1
received and implemented.” The processor
12
can then refer the reports back to its database
212
, and verify that for preset scene
1
, dimmer
1
at 100% is correct. Thus, any discrepancy between the dimmer maps
216
and the processor's master database
212
can be detected. Once preset scene
1
has been implemented, the processor
12
determines what should be shown on each display
34
for preset scene
1
, and sends out to the event initiators
28
instructions
220
on what their displays should show. These instructions may be direct, in the form “keypad
1
, turn on all your LEDs” or indirect, such as “all displays show what your local map
208
specifies for preset scene
1
.” The keypads
28
then update themselves as described in steps
198
to
202
above.
Referring to
FIG. 9
, in another example, pressing and holding button
1
on keypad
1
is intended to gradually brighten the lamps
22
involved in preset scene X. When the button is pressed, keypad
1
sends a “button pressed” message
222
to the processor
12
. As explained above, the keypad may then send a continuous stream of “button still pressed” messages that stops when the button is released, or it may send a single “button released” message when the button is released. When the processor
12
receives the “keypad
1
, button
1
pressed” message
222
, it sends out a “raise dimming level” message
224
to all dimmers
24
involved in preset X. This can be a message explicitly addressed to “all dimmers involved in preset X,” provided that the dimmers in question are programmed to recognize such a message, or it can address the dimmers individually. The command may invoke a “raise model” stored in the dimmer maps
216
(
FIG. 8
) that specifies how fast each dimmer is to change its level. As long as the button remains pressed, the processor
12
can send out a continuous stream of “continue raising” commands
226
. Instead, it can send out an initial “start raising” command and a final “stop raising” command
228
. The dimmers
24
act on these commands
224
-
228
as they are received. When the “continue raising” commands cease or the “stop raising command
228
is received, each dimmer
24
stops changing its dimming level, and sends a report
218
of its final position. The central processor
12
updates its database
212
(
FIG. 8
) to show the current level of each dimmer
24
. The actual figures reported by the dimmers are to be preferred to the levels predicted by the central processor, though any major discrepancies in the final levels may be diagnostic of discrepancies between the databases or problems in the system.
Referring now to
FIG. 10
, under some circumstances, the central processor
12
may be omitted. The processor could be entirely absent in a very simple system, or one or more individual event initiators
28
could be configured to control one or more individual device controllers
24
directly, with the central processor
12
merely monitoring and recording what happens. In this case, the databases within the system are divided into two parts, one in the device controller and one in the event initiator, to minimize message traffic and therefore to minimize required system bandwidth.
The input devices (event initiators
28
) then have button configuration information describing how to compute the LED status, because they cannot rely on status updates from the processor
12
. The button model map in the event initiators
28
must use exactly the same commands as the device model map in the device controllers
22
, because there is no central processor to convert commands from one form to the other. If a master map of the status of the controlled devices is maintained, it will usually be distributed among the event initiators
28
. If one event initiator
28
controls more than one device controller
24
, it may also have a “Button/Preset” map and a map describing which devices are affected when a button is pressed and/or a preset command is sent out.
The button/preset map tells the keypad
28
which group of dimmers
24
should acknowledge the command sent out when a button is pressed. As with the preset scene command described above, rather than sending a command to each dimmer that is affected, one preset command is sent to all of them. This conserves RF bandwidth and gives faster system response. However, if no processor
12
is involved, the preset command must be generated within the event initiator
28
. A preset command is a unique identifier for a scene. If the command as broadcast includes an event initiator address, only the combination of address and command may be unique. In that case, different keypads can be allowed to transmit identical commands in response to identical operations of their controls
32
, even if those operations have different meanings, provided that the dimmers
24
are programmed to distinguish the commands from different keypads. Instead, the command alone may be unique. The event initiator address then at most serves for verification that the preset command was issued by a keypad that exists and should be able to issue that command.
When operating dimmers with a Preset command, the keypad does not have to know anything regarding fade rates or delay times, which can be programmed into the dimmers
24
. The event initiator
28
preferably knows which device controllers
24
respond to each Preset command, for verification purposes to be explained below.
The output devices (dimmers or device controllers
24
) have a “Preset/Level” map describing the levels to turn on to, how long to delay before reacting, and how slowly to fade to their goal level for each Preset. The output devices need not know which other output devices are affected by the same Preset command.
After reacting to a Preset command, each affected output device
24
acknowledges that it received the Preset command. If the acknowledgment returns the actual final setting of the output device, then the originating event initiator must know the correct final settings for the command that it has issued. In any event, every device that has a display must be able to recognize exchanges between another keypad and one or more output devices that may require that display to be updated. If an originating device does not hear back from all of the output devices that should have been affected, it will generate an automatic reactivation and send the Preset command again.
Referring to
FIG. 10
, in one example, a user presses button
1
on keypad
1
. Keypad
1
consults its dimmer database
208
which, in the present status of the system, identifies a press of keypad
1
button
1
as a command to switch on preset scene
1
. Keypad
1
issues a “switch to Preset Scene
1
” command
230
, directly to the dimmers
24
. Each dimmer
24
that receives the command
230
looks it up in its own internal dimmer map
216
, and converts the command into instructions to delay for a specific period, then change at a specific fade rate to a specific dimming level. Each dimmer
24
executes these instructions.
Each dimmer
24
, after completing the change, sends back a report
218
. The reports
218
convey information such as “dimmer
1
now at 100% of full brightness.” The reports
218
give absolute values, rather than merely acknowledging “command to switch to preset scene
1
received and implemented.” The keypad
28
can then refer the reports back to its database
208
, and verify that for preset scene
1
, dimmer
1
at 100% is correct. Thus, any discrepancy between the dimmer maps
216
and the keypad preset maps
208
can be detected. Once preset scene
1
has been implemented, the keypad
28
determines what should be shown on its display
34
for preset scene
1
, and updates itself as described in steps
198
to
202
above. Any other devices in the system that have displays
34
monitor the dimmer reports
218
, and determine whether those affect the information shown on their own displays. Those devices then update their displays as necessary. This requires each device with a display
34
to have a detailed map of which output devices
24
its display relates to, and how they interrelate.
Databases in the input and output devices can be created in two ways: by means of a programmer (PC, GUI, etc.) using the radio link to command each unit in turn; or “manually” by walking around to each Keypad, Device, etc. and programming it locally.
Device databases and operating system updates may be downloaded to the devices over the same wireless link as is used for normal operation.
Referring now to
FIG. 11
, in step
240
a user, a host computer supplying the update, or a system device requests a Database or OS upload. The uploaded data is stored in the memory
208
or
216
on each event initiator, repeater, or device controller.
In step
242
, the central processor announces Upload Mode to all devices on the channel. While Upload Mode is in effect, the central processor has exclusive control of the wireless channel, and all devices know that they are not to transmit except in response to messages from the central processor relating to the upload process. It would be possible to upload new datasets without taking exclusive control of the wireless channel. However, the risk of packets of data being delayed, lost or corrupted because of conflicting traffic may be significant, depending on the communications protocol used. This is especially important during an OS Upload, because it is assumed that the newly uploaded data packets will immediately overwrite the previous dataset, so a device in the middle of an OS Upload may not have proper functionality.
In step
244
, the central processor notifies specific devices that are due to be receiving data. In step
246
, those devices send back a Data ID code for their current dataset. In step
248
, the central processor compares the received Data ID codes with the Data ID code for the new dataset, to determine whether the devices already have the current data. For an OS upload, the Data ID code is an OS revision number.
If any device has a dataset that is not current, a Data transfer will begin in step
250
, when the central processor sends out a packet of data to the relevant device(s). An operating system upload can be sent at one time to all units using the same operating system or the same subset of the operating system. In a typical system, many of the units will be multiple units of common types that share the same operating system. Sending to all of those units at once can thus be a great saving in volume of data transmitted. The databases used by individual devices are more likely to be subsets of the overall database that are all different, so with a database upload it is more likely to be efficient for the central processor to generate database subsets to be uploaded to individual units. In step
252
, the Device(s) respond when they are ready for more. For an OS upload, the processor queries the devices to determine when they are ready for more data. In step
254
, the central processor determines whether all data has been sent, and repeats steps
250
and
252
as necessary.
In step
256
, the processor
12
tells the devices that all of the data has been sent. In step
258
, the devices determine the Data ID for the newly-received dataset and send it to the central processor
12
. This is prompted by a query from the central processor
12
, if doing an OS Upload. In step
260
, if the new Data ID is correct, and the upload was an OS Upload, the central processor
12
tells the device(s) that the Upload is complete and that they should start running the new OS. In step
262
, the central processor
12
checks whether there are more devices to update with another dataset. If so, the process loops back to step
244
and repeats for the new dataset. Because most devices in the system have only a small subset of the overall database, and different devices may have differently optimized operating systems, or different subsets of the operating system, a major update of a large system may require several upload sessions.
Once all of the uploads are complete, in step
264
the central processor
12
tells all devices on the link to exit Upload Mode. This allows all devices to claim the link for ordinary operating messages when necessary. If less than the whole system was in an Upload Mode that excluded normal access to the communications links, the status data in event initiators, displays, and the like should be updated to reflect any system events that the unit in question missed because of the upload.
Although the invention has been described with reference to specific embodiments thereof, it will be understood that various changes may be made thereto without departing from the scope and spirit of the invention. For example, although reference has been made to radio communications, many aspects of the present invention are applicable to other parts of the electromagnetic spectrum, to broadcast media other than electromagnetic radiation, and to other means of communication, including wired networks.
Claims
- 1. A lighting control system comprising event initiators having controls operable by a user, devices controlled by said event initiators, and a central processor, wherein:said event initiators and controlled devices comprise parts of a system database; said database part within each event initiator maps operations of controls by a user to commands transmissible from such event initiator to said controlled devices; said database part within each controlled device maps commands received from an event initiator to actions of such device; said transmissible commands contain less data than is necessary to describe completely the operations of controls or the actions of devices; said event initiators are arranged to transmit to said central processor sufficient information to identify an operation of said controls by a user that validly commands the system, and said central processor is arranged to transmit commands to said controlled devices.
- 2. A system according to claim 1, wherein said controlled devices are programmed with preset states, and said transmissible commands comprise at least one command that commands at least one said controlled device to enter such a preset state.
- 3. A system according to claim 2, wherein said controlled devices are programmed with processes for entering said preset states, and no separate command to invoke said processes is transmitted.
- 4. A system according to claim 2, wherein at least some of said controlled devices are controllable over a range of operating values, and said preset states include specified operating values within such ranges.
- 5. A system according to claim 1, wherein said commands are transmitted on a shared wireless communications path.
- 6. A system according to claim 1, wherein said shared communications path is a radio channel.
- 7. A system according to claim 1, wherein said event initiators and controlled devices are each provided with an input device by means of which an operator can update said database parts.
- 8. A system according to claim 1, wherein said event initiators and controlled devices are arranged to receive updates to said database parts over the same medium through which said commands are transmitted.
- 9. A system according to claim 1, wherein each controlled device after taking action in response to a said command transmits a response indicative of an event occurring at said controlled device resulting from the action.
- 10. A system according to claim 9, wherein said response is indicative of a state of said controlled device resulting from said action.
- 11. A system according to claim 9, wherein the event initiator from which the command in question originated, on receiving the response transmitted by the said controlled device, maps the state of the said controlled device to the user control operation from which the command was mapped, and provides an indication if the control operation was correctly executed.
- 12. A system according to claim 9, wherein each event initiator comprises a display, and wherein each said event initiator is adapted, in response to operation of at least one said control, to:predict whether said operation of said at least one control will result in a change of state of said display; update said display if the predicted state of said display differs from the state of said display before said operation of at least one control; transmit a said command indicative of said operation of said at least one control; receive said response indicative of said event that actually occurs in response to said transmitted command; and update said display if a state of said display correct in view of said response differs from the state of said display as updated on the basis of said prediction.
- 13. A system according to claim 12 that is arranged to emit a signal if said display is updated more than a predetermined time after detecting said operation of said at least one control.
- 14. A system according to claim 12, that is arranged to update said display in response to other instructions received.
- 15. A lighting control system comprising event initiators having controls operable by a user and devices controlled by said event initiators, wherein:said event initiators and controlled devices comprise parts of a system database; said database part within each event initiator maps operations of controls by a user to commands transmissible from such event initiator to said controlled devices; said database part within each controlled device maps commands received from an event initiator to actions of such device; said transmissible commands contain less data than is necessary to describe completely the operations of controls or the actions of devices; and each controlled device after taking action in response to a said command transmits a response indicative of an event occurring at said controlled device resulting from the action.
- 16. A system according to claim 15, wherein said response is indicative of a state of said controlled device resulting from said action.
- 17. A system according to claim 15, wherein the event initiator from which the command in question originated, on receiving the response transmitted by the said controlled device, maps the state of the said controlled device to the user control operation from which the command was mapped, and provides an indication if the control operation was correctly executed.
- 18. A system according to claim 15, wherein each event initiator comprises a display, and wherein each said event initiator is adapted, in response to operation of at least one said control, to:predict whether said operation of said at least one control will result in a change of state of said display; update said display if the predicted state of said display differs from the state of said display before said operation of at least one control; transmit a said command indicative of said operation of said at least one control; receive said response indicative of said event that actually occurs in response to said transmitted command; and update said display if a state of said display correct in view of said response differs from the state of said display as updated on the basis of said prediction.
- 19. A system according to claim 18 that is arranged to emit a signal if said display is updated more than a predetermined time after detecting said operation of said at least one control.
- 20. A system according to claim 18 that is arranged to update said display in response to other instructions received.
- 21. A lighting control system comprising an event initiator having a control operable by a user, a central processor, and a device controlled by said event initiator, wherein:said event initiator and said controlled device comprise parts of a system database; said database part within said event initiator maps an operation of said control by a user to a first command transmissible from said event initiator; said event initiator is arranged to transmit to said central processor sufficient information to identify said operation of said control that validly commands the system; said central processor is arranged to transmit a second command to said controlled device; said database part within said controlled device maps said second command received from said event initiator to an action of said device; said first and second commands contain less data than is necessary to describe completely said operation of said control or said action of said device.
- 22. A system according to claim 21, wherein said controlled device is programmed with a preset state, and said second command commands said controlled device to enter said preset state.
- 23. A system according to claim 22, wherein said controlled device is programmed with a process for entering said preset state, and no separate command to invoke said process is transmitted.
- 24. A system according to claim 22, wherein said controlled device is controllable over a range of operating values, and said preset state includes a specified operating value within said range.
- 25. A system according to claim 21, wherein said first and second commands are transmitted on a shared wireless communications path.
- 26. A system according to claim 21, wherein said shared communications path is a radio channel.
- 27. A system according to claim 21, wherein said event initiator and said controlled device are each provided with an input device by means of which an operator can update said database parts.
- 28. A system according to claim 21, wherein said event initiator and said controlled device are arranged to receive updates to said database parts over the same medium through which said first and second commands are transmitted.
- 29. A system according to claim 21, wherein said controlled device after taking said action in response to said second command transmits a response indicative of an event occurring at said controlled device resulting from said action.
- 30. A system according to claim 29, wherein said response is indicative of a state of said controlled device resulting from said action.
- 31. A system according to claim 29, wherein said event initiator, on receiving said response transmitted by said controlled device, maps the state of said controlled device to said operation of said control from which said first command was mapped, and provides an indication if said operation of said control was correctly executed.
- 32. A system according to claim 29, wherein said event initiator comprises a display, and wherein said event initiator is adapted, in response to said operation said control, to:predict whether said operation of said control will result in a change of state of said display; update said display if the predicted state of said display differs from the state of said display before said operation of said control; transmit said command indicative of said operation of said control; receive said response indicative of said event that actually occurs in response to said command; and update said display if a state of said display correct in view of said response differs from the state of said display as updated on the basis of said prediction.
- 33. A system according to claim 32 that is arranged to emit a signal if said display is updated more than a predetermined time after detecting said operation of said control.
- 34. A system according to claim 32 that is arranged to update said display in response to other instructions received.
- 35. A lighting control system comprising an event initiator having a control operable by a user and a device controlled by said event initiator, wherein:said event initiator and said controlled device comprise parts of a system database; said database part within said event initiator maps an operation of said control by a user to a command transmissible from said event initiator to said controlled device; said database part within said controlled device maps said command received from said event initiator to an action of said device; said command contains less data than is necessary to describe completely said operation of said control or said action of said device; and said controlled device after taking said action in response to said command transmits a response indicative of an event occurring at said controlled device resulting from said action.
- 36. A system according to claim 35, wherein said response is indicative of a state of said controlled device resulting from said action.
- 37. A system according to claim 35, wherein the event initiator, on receiving said response transmitted by the said controlled device, maps the state of said controlled device to said operation of said control from which said command was mapped, and provides an indication if said operation of said control was correctly executed.
- 38. A system according to claim 35, wherein said event initiator comprises a display, and wherein said event initiator is adapted, in response to said operation said control, to:predict whether said operation of said control will result in a change of state of said display; update said display if the predicted state of said display differs from the state of said display before said operation of said control; transmit said command indicative of said operation of said control; receive a response indicative of an event that actually occurs in response to said command; and update said display if a state of said display correct in view of said response differs from the state of said display as updated on the basis of said prediction.
- 39. A system according to claim 38 that is arranged to emit a signal if said display is updated more than a predetermined time after detecting said operation of said control.
- 40. A system according to claim 38 that is arranged to update said display in response to other instructions received.
US Referenced Citations (9)
Number |
Name |
Date |
Kind |
4980806 |
Taylor et al. |
Dec 1990 |
A |
5406176 |
Sugden |
Apr 1995 |
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 |
5982103 |
Mosebrook et al. |
Nov 1999 |
A |
6605907 |
Belliveau |
Aug 2003 |
B2 |
6687487 |
Mosebrook et al. |
Feb 2004 |
B1 |