This application claims the benefit of European Application No. 08165844.5, entitled, “A UNIVERSAL REMOTE CONTROL DEVICE”, filed Oct. 3, 2008, which is hereby incorporated herein by reference in its entirety.
U.S. Pat. No. 4,774,511 describes a universal remote control unit which is able to control a number of different devices such as, a TV, a VCR, a disc player and an audio system. US 2008/0158038 describes the “TV-B-Gone” device which is able to power off TV sets made by different manufacturers.
There is a need for a universal remote control device which can be programmed to fully operate different brands of televisions, for example, and/or can be used to control other types of devices, such as recording devices, and set top boxes, which are used in conjunction with a TV. However, presently the universal remote control devices which are available are either limited in the number of different components they can be programmed to control or, as in the “TV-B-gone” device, are limited in the control functions they can provide.
According to a first aspect of the present invention there is provided a universal remote control device having a user interface, and transmission means for transmitting commands to electronic devices, the universal remote control device comprising processing means and associated memory, wherein, to enable the universal remote control device to provide commands to operate a plurality of electronic devices, a database is stored in the memory, the database containing control data which has been collected from a plurality of individual, physical remote control units, where each individual remote control unit is arranged to operate a respective one of the electronic devices, and
wherein control data which is common to a number of the physical remote control units is stored in virtual remote structures in the database, and
wherein a physical remote structure which corresponds to a selected one of the physical remote control units stores control data specific to that physical remote control unit and is linked to appropriate ones of the virtual remote structures whereby all the control data for that physical remote control unit can be retrieved.
Embodiments of the invention seek to store all of the control data necessary to ensure that the functionality of the universal remote control device is not limited, but to keep the size of the database small so that the memory required can also be kept small. This has led to the use of a database structure, in embodiments of the invention, in which common control data is stored in virtual remote structures which are available to a number of physical remote structures.
In a preferred embodiment, the virtual remote structures and physical remote structures are hierarchically arranged, with the physical remote structures being at the lowest or child level and the virtual remote structures being arranged in one or more upper or parent levels, such that each physical remote structure can inherit control data from one or more parent virtual remote structures.
The use of inheritance in embodiments of the present invention reduces the overall size of the data considerably.
In a preferred embodiment, the control data stored at the lowest or child level has a higher priority than control data stored at a higher or parent level, and it is arranged that on retrieval, any conflicts are resolved by retrieving the highest priority control data.
The provision of specific data for a remote in a child physical remote structure, which is also linked to one or more virtual parent remotes, reduces the size of the control data which has to be stored considerably. Conflicts are resolved by the use of priorities.
However, the physical remote control units, whose functions are to be undertaken by a universal remote control device of the invention may, themselves, have multiple functions and/or multiple protocols. In such a case, the physical remote structure, the child, can be provided with all of the data relating to one protocol, and a parent, virtual remote structure can be provided with additional data which relates to a second protocol. Alternative data can also be stored in the physical and virtual remote structures.
In this scenario, the control data stored at a higher or parent level has a higher priority than control data stored at the lowest or child level and it is arranged that on retrieval, any conflicts are resolved by retrieving the highest priority control data.
The control data determines commands to be transmitted to electronic devices. In an embodiment, if the control data it is required to retrieve for a particular command is absent from the remote structures having the higher priority, the required control data is retrieved from remote structures having a lower priority.
Other methods may be utilized to reduce the physical size of the control data as stored. For example, the size of the control data stored may be reduced by omitting repetitious and/or redundant control data.
In an embodiment, where the universal remote control device has a plurality of keys, and actuation of individual keys is arranged to output commands for transmission to electronic devices, only the commands of keys which output commands for transmission are stored in the database.
Preferably, key mapping is used to indicate which keys output commands.
In a preferred embodiment of a universal remote control device of the invention, where actuation of keys is arranged to output commands for transmission to electronic devices to operate those electronic devices, bit repetition data from the output commands is stored together with data, for each command, as to the bit position and the number of bit repetitions, such that each required output command need not be stored but can be generated from the data stored.
Each individual remote control unit may have an individual identification, for example, “CodeID”. Rather than storing each individual identification, which would use a lot of memory, an embodiment of the invention provides that the database stores the identification of a first remote control unit, and then stores only the relative jump from the identification of each remote control unit to the next remote control unit.
Preferably, and again to reduce the amount of information which has to be stored, control data for remote control units is stored in global tables, and the structure and control data for each remote control unit is stored using indexes which point to the control data to be retrieved.
The present invention also relates to a method of providing a universal remote control device, comprising
collecting control data for each one of a plurality of individual, physical remote control units, and arranging the collected control data in a database,
storing the formed database in a single, universal remote control device, and
arranging that the universal remote control device is operable to perform the functions of each one of the physical remote control units of the plurality by selectively retrieving the control data for each one of the physical remote control units from the database,
wherein control data which is common to a number of the physical remote control units is stored in virtual remote structures in the database, and
wherein a physical remote structure which corresponds to a selected one of the physical remote control units stores control data specific to that physical remote control unit and is linked to appropriate ones of the virtual remote structures whereby all the control data for that physical remote control unit can be retrieved.
In an embodiment, the virtual remote structures and physical remote structures are hierarchically arranged, with the physical remote structures being at the lowest or child level and the virtual remote structures being arranged in one or more upper or parent levels, such that each physical remote structure can inherit control data from one or more parent virtual remote structures.
In an embodiment, the control data stored at the lowest or child level has a higher priority than control data stored at a higher or parent level, and it is arranged that on retrieval, any conflicts are resolved by retrieving the highest priority control data.
Alternatively, the control data stored at a higher or parent level has a higher priority than control data stored at the lowest or child level, and it is arranged that on retrieval, any conflicts are resolved by retrieving the highest priority control data.
In an embodiment, where the control data determines commands to be transmitted to electronic devices, and the control data it is required to retrieve for a particular command is absent from the remote structures having the higher priority, the method further comprises enabling the required control data to be retrieved, in such circumstances, from remote structures having a lower priority.
Preferably, a method of the invention further comprises omitting repetitious and/or redundant control data from the control data stored to reduce the size of the control data stored.
In an embodiment of a method of the invention, where each individual remote control unit has an individual identification, the identification of a first remote control unit is stored in the database, and then only the relative jump from the identification of each remote control unit to the next remote control unit, starting from the first, is stored.
Preferably, control data for remote control units is stored in global tables, and the structure and control data for each remote control unit is stored using indexes which point to the control data to be retrieved.
Embodiments of the present invention will hereinafter be described, by way of example, with reference to the accompanying drawings, in which:
Embodiments of the invention provide a universal remote control device which is able to operate different electronic devices, such as television sets, recording devices such as VCRs and DVD recorders, set top boxes and satellite systems, and audio systems. The universal remote control device is also able to operate different manufacturers' versions of such devices. In one embodiment, for example, the universal remote control device is able to provide the functionality of 740 individual remote control units.
It will be appreciated that a universal remote control device implementing the invention may control as few or as many electronic devices as is commercially required, and may control as many or as few types of electronic devices as meets the needs of the marketplace.
A remote control unit communicates with the electronic device it controls by transmitting signals and, presently the majority of remote control units use infrared (IR) transmissions. However, the invention is not limited to the use of infrared transmissions and comprehends remote control units communicating with the electronic devices they control by any other suitable means, for example, by “Bluetooth” ® or by radio frequency transmissions.
To provide a universal remote control device which is not limited in its functionality, as are the presently available devices, it is clearly necessary to store the control data from a very large number of individual, physical remote control units. This data storage is within the universal remote control device.
It is not generally commercially possible just to provide a very large capacity memory within the universal remote control device. Commercial remote control units, for example, typically have ROM memory incorporated therein with a capacity limited to 32 KB. Unfortunately, ROM storage remains relatively expensive and so a viable universal remote control device needs to store the large amount of data necessary without needing to increase the memory capacity. It is therefore proposed to compress the data. Of course, it is then necessary to ensure that decompression of the data is easy and that it does not take too long. An electronic device controlled by a universal remote control device is generally controlled by pressing a key, and the user expects that once a key is pressed there will be a substantially immediate response from the electronic device.
The requirement to compress the data so that it can be stored in a relatively small capacity memory, of course, conflicts with the need to make the data immediately accessible when required.
Embodiments of the invention address these conflicting requirements. In preferred embodiments, not only is the control data to be stored compressed, it is also stored in a specific database structure which utilizes inheritance. This database structure enables a large amount of data to be stored in a small space but yet makes access to that data easy and fast.
The compression techniques utilised, in the main, omit redundant or repeated information. Specific examples of such techniques are illustrated and described. It will be appreciated that any other compression techniques can be additionally, and/or alternatively used.
The various compression techniques are now described with specific reference to IR transmissions. It will be appreciated that different compression techniques might occur to the skilled man if alternative means for transmission are employed.
As explained, a universal remote device 100, as indicated in
It will be apparent from
In embodiments, the control data from each remote control unit which needs to be stored is compressed, as discussed above. This can be done by using key mapping.
Key mapping is used to indicate which keys of a physical remote control unit 2 generate IR patterns. As is shown, each key is given a number or position (
Only the commands of keys which output IR patterns are stored in the database in the universal remote control device 100. The storage is in order with the lowest “embedded key number” first and the keys with the highest “embedded key number” last. The keys and command numbers which are to be stored are shown in
The command number in the table of
The command number is not stored in the database but is always calculated. So, for example, the command number of the “Mute” key can be obtained by finding that the embedded number for the “Mute” key in
In some instances, a remote control unit will have multiple events accessed by pressing the same key. Normally a key event with two commands will send command 1 once, and command 2 unlimited times until the key is released. Thus, both commands belong to the same event and are sent out by one key press, that is, by actuating one key once only.
For example, amplifier devices have different keys to select the input device. A remote control unit for an amplifier may have a key to select the TV as the input device, another key to select the DVD as the input device, and still a further key to select the VCR as the input device. The commands from such keys cannot be placed under “TV” and “VCR” keys of a universal remote control device as such keys are required to change the mode of the universal remote control device and not to send out IR patterns. This situation is dealt with by placing all of these events under a single “Select” key. The first time the “Select” key is pressed, a “Select TV” command is sent, the next time the key is pressed a “Select DVD” pattern is sent, and if the key is pressed again, a “Select VCR” pattern is sent.
When a remote control unit has multiple events under the same key, the key commands can be stored as shown in
It will be appreciated from the above that the data to be stored in the database is reduced by storing only the commands of keys which output IR patterns and by causing the universal remote control device to calculate the command numbers. Another way in which the data to be stored can be reduced in size is by storing bit repetition data rather than every IR pattern.
There are other methods of avoiding the storage of repetitious values which will occur to those skilled in the art but which are not described in detail here. However, it is suggested that anything which is repeated should generally be stored only once together with appropriate pointers to the information.
As set out above, the embedded database within the universal remote control device is to store the control data collected from a plurality of individual physical remote control units 2. In one embodiment, this control data is stored in four distinct lists, a TV remote list, a VCR/DVD remote list, an amplifier remote list and a satellite or set top box remote list. All of the remote control units are allocated to one of the lists and their control data placed in the allocated list. Each remote control unit 2 which is operable to control a TV is placed in the TV remote list, a portion of which is illustrated in
It will be appreciated that storing the “CodeID” for every remote control unit would take a lot of memory. Accordingly, the database stores only the relative jump from one “CodeID” to the next as illustrated in
To obtain the jump codes, the remote control units are sorted on “CodeID” from low to high. The “CodeID” of the first remote in the list is stored as defined in the database, and these definitions are
The “CodeID” of the first remote is:
The “CodeID” of the other remotes is:
CodeID next remote=CodeID+JumpCode+1
If the value of the “Code ID” of TV_START_JUMP_CODE is 2, the jump code table shown in
As set out above, it is a waste of memory to store the same information for different remotes, or to store duplicated information from a single remote, a number of times. Many remotes have the same frequency, high times or key mapping which can be stored as common data. Similarly, and as described above, repetitious data, such as particular bit patterns and general command information can be stored only once.
Memory can be saved by storing the key mapping in a global table. To this end, every remote has an index which refers to an entry in the key mapping table. Less memory is required to store an index than to store the key mapping.
Where many remotes have the same data, their key mappings can be stored using indexes as shown in
Let us assume that there are 740 individual physical remote control units, the key mapping size is 47 bits, and the number of distinct key mappings is 243.
A reference to one of these 243 key mappings can be stored into 8 (log 2 (243)) bits. Per remote only 8 bits are needed, instead of the 47 bits for the real key mapping.
The size that is needed to store the key mappings is shown in the examples below. The first example does not use a key mapping table, and the second example makes use of the key mapping table.
Size without a key mapping table:
Size with a key mapping table:
It will be seen that the total size is halved when using the global key mapping tables.
As set out above, the control data which is to be stored in the database 10 is to be stored, for example, as command bits, remote lists, key mappings, and frequency, timing and other data about the remotes. Indexes are used to access the data.
As described above, the remote information 20 includes four remote lists which contain the control data for four types of physical remotes identified using jump codes. As shown in
Every physical remote control unit 2 belongs to a protocol. The protocol type information, which is set out in table 32, is needed to convert the high times, low times and command bits to an IR pattern. The protocol properties are stored in the table 32. Every protocol also has a “protocol state diagram”, which is not shown in
Properties that are the same for every IR pattern to be generated are placed in the “General Command Info” structure 34. These variables include the repeat count, the fixed key length and the interkey time. The repeat count indicates how many times the command must be repeated when the key is pushed continuously. The fixed key length and the interkey time are used to define the interword gap (IWG).
The key mapping and the command information which is stored in the database structure of
Is the key available?
What is the command position?
Where are the command bits stored?
Has the command “bit repetition data”?
The “Key mapping” table 22 indicates which keys are available. Each remote has an index in the “RemoteInfo” table 30 which refers to a “Key mapping”. When the “Key mapping” flag of the pressed key is “1”, the key is available. Otherwise the remote does not have the key.
The “Key mapping” and “Command Repetition Info” are needed to get the position, that is, the command number, of the pressed key. The “Key mapping” indicates which keys are available. The “Command Repetition Info” indicates which keys have multiple events.
As shown in
The “Command_Table_ID” of “Command 2” is “4”. This looks strange, because there is no command table 4. When the “Command_Table_ID” is equal to the number of command tables this means that “Command 2” does not have command bits. This remote does not have command bits for the second command.
As described above, some remotes contain the real command bits, and not indexes to command bits as described above. These command bits are stored at the same position as where, in this example, the command indexes are stored. The remotes with real command bits still have a “Command_Table_ID”. The command table is needed to get the size of the command bits. The size of the command bits is stored in the “Entry_Size” variable of the command table.
The last question is, has the command “Bit repetition data”? When the remote contains “Bit repetition data”, this must be inserted to the command bits.
After this step all command bits are accumulated and can be used to generate the IR pattern.
In the description above, it has been explained how the control data can be reduced in size by omitting redundant or repeated values in the data as shown. An illustrated example of a database structure utilizing pointers and other database techniques to provide access to the stored data has also been described.
A database structure of embodiments of this invention uses a compression method called inheritance. This enables common properties to be communally stored. Inheritance also enables the support of multiple protocols per physical remote control unit.
The control data of individual remote control units is stored in the database as one or more tables.
It is proposed that, additionally, virtual remotes should be provided, as indicated in
When it is required to obtain the control data for a physical remote 40, first of all any data in the physical remote 40 itself is obtained, then further data is taken from the parent or the grandparent and so on.
The data of the child, that is of the physical remote 40, has a higher priority than the data of the parent. Thus, in
It will be seen that, in the structure of
So, if a physical remote has a parent it has an index to this parent.
It will also be seen in
Some remotes support multiple protocols. In this case, some keys of the remote will use one protocol, say X, whilst others will use a different protocol, say Y. When the protocol is different the variables are usually different. Thus, the high times, the low times, the interword gap, and the command length vary from protocol to protocol.
In the arrangement of
There are two rules for inheritance. The normal inheritance rule is that the child data has a higher priority than the parent data. However, and as described above, where there is a multiple protocol, indicated by the setting of a “multi_protocol_bit” to 1, the inheritance rule is changed and the parent data is given a higher priority than that of the child data.
In the arrangement shown in
Some remotes which only have a single protocol might still use the multiple protocol mechanism as indicated in
In this situation, all common settings are stored in the child remote and then the child contains the “general command info” for the child's keys and the parent contains the “general command info” for the parent's keys.
There are three data types to indicate which data the remote has. These are the “Has_Parent” flag, the “Has_Mask” flag and the “Property_Mask”. The “Has_Parent” flag indicates whether the remote has a parent or not. The “Has_Mask” flag indicates if the remote has a property mask. The property mask is a list of six flags, namely a key mapping bit, a frequency index bit, a protocol type bit, a high time table bit, a low time table bit and a general command info bit. This is shown schematically in
Not all remotes have a property mask. Where there is not a property mask the “Has_Parent” flag indicates if the remote has the six properties. When the “Has_Parent” flag is “1” the remote has none of the six properties, and when the “Has_Parent” flag is “0” the remote has all of the six properties.
The keys of the remote can be stored in different remotes. If the key mapping bit is “1” the remote has a key mapping and commands. When two remotes have the same pattern, this pattern can be stored in the parent remote instead of twice in the child remote. If the pattern only belongs to one remote, the pattern is stored in the child remote.
As indicated in
As set out above, “Command Repetition Info” is used to indicate which keys have multiple events per key. Where the patterns for these events have differing protocols then the patterns with protocol X are stored in the child remote and the patterns with protocol Y are stored in the parent remote.
In the example shown in
It will be appreciated that compression of the data in the data structure can be utilized using the inheritance format described above. Other control data which may occur multiple times, such as general command information, can be split between child and parent remotes.
It will be appreciated that variations and modifications to the matters described and illustrated can be made within the scope of the present invention as defined in the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
08165844.5 | Oct 2008 | EP | regional |