The present disclosure relates to systems and methods for controlling luminaires, i.e. lighting devices, to render a lighting effect a physical space.
Electronic devices are becoming ever more connected. A “connected” device refers to a device—such as a user terminal, or home or office appliance or the like—that is connected to one or more other such devices via a wireless or wired connection in order allow more possibilities for control of the device. For instance, the device in question is often connected to the one or more other devices as part of a wired or wireless network, such as a Wi-Fi, ZigBee or Bluetooth network. The connection may for example allow control of the device from one of the one or more other devices, e.g. from an app (application) running on a user device such as a smart phone, tablet or laptop; and/or may allow for sharing of sensor information or other data between the devices in order to provide more intelligent and/or distributed automated control.
In recent years, the number of connected devices has increased dramatically. Lighting systems are part of this movement towards a connected infrastructure. Conventional connected lighting systems consist of fixed light sources, which can be controlled through wall-mounted switches, dimmers or more advanced control panels that have pre-programmed settings and effects, or even from an app running on a user terminal such as a smart phone, tablet or laptop. For example, this may allow user to create an ambiance using a wide range of colored lighting, dimming options and/or dynamic effects. In terms of control the most common approach is to replace a light switch with a smartphone based app that offers extended control over lighting (for example Philips hue, LIFX, etc.).
A lighting scene is a particular overall lighting effect in an environment rendered by the light sources in that environment. E.g. a “sunset” scene may be defined in which the light sources are set to output hues in the red-yellow range of the visible spectrum. Each light source may for example output the different hues (or other setting such as saturation or intensity), or a scene may be rendered by all (or some) lights rendering a single color or similar colors. Note that lighting scenes may be dynamic in that the output of one or more light source changes over time.
Connected lighting systems are able to render lighting scenes by receiving lighting instructions over the network (e.g. a ZigBee network) from, for example, a user device such as a smart phone, and interpret the lighting instructions in order to determine the appropriate lighting settings for each light source in order that the lighting system renders a desired lighting scene in the environment.
When a user of a lighting system (e.g. his own lighting system deployed in his home) wishes to render a lighting scene, he can select (using a user device such as a smart phone) a predefined lighting scene which specifies respective lighting settings for each luminaire in the system. This predefined lighting scene may have been designed by the user at an earlier time and stored to memory (e.g. n the user device) for rendering. In recent years however, it has become possible for a user to retrieve lighting scenes from a third party source (e.g. over the Internet) which were designed by a person other than the user himself
Connected lighting systems can be used to render light effect which can enhance many forms of entertainment; music, movies, or gaming experiences etc. A user may wish to render an external lighting scene (i.e. a lighting scene which was defined by a different user) in his personal lighting system. However, the different user may not have designed the lighting scene with the user's lighting system in mind and therefore mapping lighting content of the scene to the actual setup of the user using it may be difficult, as setups may differ.
Specifically, one difficulty with rendering light effects in a complete room is that the setup of light points differs between homes. There is no universal setup and lighting content created for one setup may not render nicely, or may not render at all on other setups. The present invention provides a mechanism that allows content creators to define lighting effects without foresight of any particular lighting system setup on which it is to be rendered. The lighting effect(s) can for example be embodied in a lighting script, to be rendered by a controller, where the controller (rather than the context creator) takes into account the lighting system setup automatically.
The present invention solves this problem by using “virtual object(s)” which are defined independently of a particular lighting system to determine settings for a particular luminaire. A virtual object is an entity defined by its location in a virtual space and the extent to which it influences its surroundings (influence value). To render a lighting effect, a separation in physical space between a luminaire and a location corresponding to the virtual object is determined, and light emitted by the luminaire is set as a function of the separation and the influence value.
Conceptually, it can be useful to think of this as the virtual object exerting an effect on the luminaire that is comparable to a “gravitational pull”, where the influence value acts to some extent as a “mass” of the virtual object, determining the strength of its gravitational pull.
Hence, according to a first aspect disclosed herein there is provided a method of controlling a luminaire at a first physical location in a physical space to render a lighting effect in the physical space, the method being performed by a control device and comprising steps of: receiving at least one data object for use in rendering the lighting effect, the data object defining at least one virtual object comprising an influence value for the virtual object and a coordinate vector denoting a virtual location of the virtual object in a virtual space; determining the first physical location of the luminaire in the physical space from a map of the physical space; determining a separation between the first physical location of the luminaire and a second physical location in the physical space corresponding to the virtual location of the virtual object in the virtual space; and controlling at least one characteristic of light emitted by the luminaire as a function of the determined separation and the influence value for the virtual object, thereby rendering the lighting effect.
In embodiments, the method further comprises a step of mapping the virtual location denoted by the coordinate vector of the virtual object to the second physical location within the physical space.
In embodiments, the influence value is an influence radius and said function varies between a maximum at zero separation and zero at separation equal to the influence radius.
In embodiments, said at least one characteristic is one or more of a brightness or saturation of the light emitted by the luminaire.
In embodiments, the data object defines: a first virtual object comprising a first influence value for the first virtual object and a first coordinate vector denoting a first virtual location of the first virtual object in a virtual space; and a second virtual object comprising a second influence value for the second virtual object and a second coordinate vector denoting a second virtual location of the second virtual object in the virtual space.
In embodiments, said determining a separation comprises determining a respective separation for each of the first and second virtual objects; and said controlling is performed as a function of the determined separations, the first influence value, and the second influence value.
In embodiments, the method further comprises a step of determining a winning virtual object according to a predetermined rule; and wherein said controlling is performed based only on the respective separation and influence value for the winning virtual object.
In embodiments, wherein the predetermined rule is that the winning virtual object is a one of the first and second virtual objects having a highest function value at the physical location of the luminaire.
In embodiments, the predetermined rule is that the winning virtual object is a one of the first and second virtual objects having the highest respective influence value.
In embodiments, the at least one characteristic is at least one of a brightness, saturation, hue, or timing of a dynamic effect.
In embodiments, the method further comprises a step of performing the method steps to control at least one further luminaire at a respective further physical location in the physical space to render a further lighting effect in the physical space.
In embodiments, wherein the at least one characteristic is varied based on number of luminaires within range of the virtual source.
According to a second aspect disclosed herein, there is provided a control device for controlling a luminaire at a first physical location in a physical space to render a lighting effect in the physical space, the control device comprising: an output for sending control commands to the luminaire; a first input for receiving at least one data object for use in rendering the lighting effect, the data object defining at least one virtual object comprising an influence value for the virtual object and a coordinate vector denoting a virtual location of the virtual object in a virtual space; and a processor arranged to: determine the first physical location of the luminaire in the physical space from a map of the physical space; determine a separation between the first physical location of the luminaire and a second physical location in the physical space corresponding to the virtual location of the virtual object in the virtual space; and control, via the output at least one characteristic of light emitted by the luminaire as a function of the determined separation and the influence value for the virtual object, thereby rendering the lighting effect.
According to a third aspect disclosed herein, there is provided a lighting system comprising the control device of the second aspect and the luminaire.
According to a fourth aspect disclosed herein, there is provided a computer program product comprising computer-executable code embodied on a computer-readable storage medium arranged so as when executed by one or more processing units to perform the method according to the first aspect.
According to another aspect disclosed herein, there is provided a method of controlling a luminaire at a first location in a space, the luminaire arranges for illuminating the space, the method being performed by a control device and comprising steps of: receiving at least one data object for use in rendering a lighting effect, the data object comprising a location value and a range value; determining the first location of the luminaire in the space; determining a separation between a second location in the space corresponding to the location value in the data object and the first location of the luminaire, wherein the second location is different from the first location; and controlling at least one characteristic of light emitted by the luminaire as a function of the determined separation and the range value, thereby rendering the lighting effect.
To assist understanding of the present disclosure and to show how embodiments may be put into effect, reference is made by way of example to the accompanying drawings in which:
Described embodiments relate to rendering a lighting scene by a connected lighting system, the scene being specified by a light or lighting script. The light script (the content of the lighting scene) comprises one or more virtual objects (virtual sources of lighting effects) within a virtual space, and luminaires of the system which exist in a physical (real-world) space can be associated with virtual objects to determine their lighting setting in a manner analogous to a “gravitational model”. In a simple example, each virtual object is associated with an influence range which defines a respective area/volume. Luminaires within that area/volume are then influenced by that virtual object. The influence range may be considered a “pull” factor, which “draws in” a nearby luminaire and sets it to the light state of that area, in an analogous way to the Gravitational Force. In the simplest case, the influence range can be defined by a single influence value, that defines an influence range corresponding to a circle or sphere about the virtual object. To extend this, multiple influence values can define influence ranges corresponding to more complex areas/volumes of space.
In other words, an external or third party user can define a lighting scene by way of a lighting script which defines an abstract (virtual) space. The lighting script comprises one or more data objects, each of which defines a virtual object at a location in the space. Thus, this allows the scene to be defined without the need to tie it to any particular lighting system setup. The lighting script can then be applied to a user's lighting system by mapping the abstract space of the lighting script to the real-world environment the user wishes to render it in, and determining the influence of each data object on each real-world luminaire in the user's system. This model advantageously separates content creation from actual application.
In the simplest case, the data object consists of a coordinate vector denoting a location of the virtual object and at least one influence value which defines the extent to which the virtual object influences luminaires in its vicinity. That is, the term “data object” refers to the underlying data structure that defines a virtual object. Note, for conciseness, the description sometimes uses the term “virtual object” in reference to the underlying data; it will be clear in context what is meant.
In a simple example, the distance to every luminaire is computed for every virtual object source location. If the distance to the luminaire is smaller than the pull factor (influence value/range) the light is “attracted to” the light state that belongs to that source. This distance may be computed in a 2-dimensional or 3-dimensional space. That luminaire is then controlled according to the light state of that virtual object.
For ease of understanding, the following first describes a generic lighting system in accordance with embodiments of the present invention, and then subsequently describes methods and controllers according to the present invention which may be implemented by and in the lighting system.
The plurality of luminaires 101a-d along with a lighting bridge 307 form a connected lighting network controllable be at least one control device (e.g. user device). There may also be one or more switches and/or one or more sensors present as part of the connected system, as in known in the art but not shown in
Note that connected lighting systems exist which do not comprise a lighting bridge as described above. In these cases lighting control commands may be provided directly to each luminaire (i.e. instead of via a bridge). What is important is that a connected lighting system comprises luminaires which can communicate with a control device (e.g. a user device) and therefore be controlled. The luminaires may or may not be able to communicate with each other.
Lighting bridge 307 is arranged at least to send lighting control commands to luminaires 101a-d.
As illustrated in
A data object specifies a virtual object 4 in a virtual space 200. The virtual object 4 is at a virtual location within the virtual space as represented by coordinate vector 5. The virtual object 4 also comprises an influence value 6 which specifies an influence range which in the simplest cases can be visualized as in
A physical space map specifies the location of a luminaire 101 within a physical space 201. The physical space 201 is the real-world space in which the user's lighting system 100 is deployed (i.e. environment 103 from
The data object is transformed into the same real-world positioning scheme as that in which the luminaire 101 is specified. This may involve scaling, rotating, sheering, or otherwise transforming of the virtual space 200. This transformation may be specified by the user 309 e.g. using a graphical interface on the user device 311, or the controller can determine an appropriate transformation automatically (e.g. by maximizing the amount of the physical space which is covered by the transformed data object). In any case, the result is a “real-world” location for the virtual object. This is shown in
The physical locations of both the virtual object 4 and the luminaire 101 can be combined as shown in
In
Similarly, a lighting infrastructure map 212 specifies the location of the luminaire 101 within the physical space 201. This map 212 may be constructed by the user 309 (or a commissioner of the lighting system 100 during a commissioning process) by known methods which allow the locations of luminaires to be determined and recorded.
Table 211 shows the transformed version of the virtual object 4 which now comprises a physical location denoted by vector coordinate 15.
The separation between the luminaire 101 and the virtual object 4 within the physical space 201 can now be calculated. In the simplest cases, this separation is calculated as the Euclidean distance between the two points, as shown in
The controller 400 may be implemented in the user device 311, the bridge 307, one of the luminaires 101 and perform the functionality described herein. Alternatively, the controller 400 may be implemented in a distributed manner, with some functionality being performed at one physical device of the lighting system (e.g. the user device 311, bridge 307, or a luminaire 101) and other functionality being performed at a different physical device. This different physical device may be a physical device present in the environment 103 (e.g. the user device 311, the bridge 307, or a luminaire 101) or may be a remote device such as a remote server accessible over the Internet 313.
The first input 401 is arranged to receive the data object 210 (described above). The data object 210 may be stored on an external memory such as memory 315 in which case the data object is received at the first input 401 via a network such as the Inter 313. Alternatively, the data object 210 may be stored on a local memory, internal to the controller 400.
The second input 402 is arranged to receive a lighting map 212 (described above). The lighting map 212 may be stored on an external memory such as memory 315 in which case the data object is received at the first input 401 via a network such as the Inter 313. Alternatively, the lighting map 212 may be stored on a local memory, internal to the controller 400.
The processor 403 is arranged to receive the data object 210 via the first input 401, and to receive the lighting map 212 via the second input 402. The processor 403 is further arranged to process the received data object 210 and lighting map 212 in accordance with methods described herein to generate lighting control commands for at least one luminaire 101.
The output 404 is for at least sending data to, and optionally receiving data from, the at least one luminaire 101 in accordance with known lighting control protocols. The processor 403 is arranged to transmit at least one generated lighting control command to the at least one luminaire 101 and hence control at least one characteristic of the light emitted by the luminaire in accordance with the lighting control commands.
The processor may also be arranged to receive input from the user 309 via a user device 311 (or other computing device) via a third input 405, as shown in
In the most general terms, the processor 403 is arranged to receive the data object (which specifies at least one virtual object being at a virtual location, and having an influence value), determine a physical location of a luminaire 101, determine a separation between the physical location of the luminaire and a physical location corresponding to the virtual location of the virtual object, and control the luminaire 101 based on a function of both the separation and the influence value.
There are several ways in which this function may be implemented, examples of which are shown in
In the example of
An extension to this is that the source may specify a variation parameter for the light state. This parameter determines how much variation is tolerated for luminaires that are attracted to that source. For example, the light state of the source may define a xy-color parameter, but with a variation of 0.05. This means that lights that are further away from the source may have slightly different color tones as the main color. In other words, the variation parameter acts in the same way as the example given above in relation to
The alteration of the lighting output of a luminaire 101 may depend on other factors in addition to the separation between it and a virtual object 4. For example, In circumstances where there are multiple luminaires 101a, 101b within influence range of a single virtual object 4, the respective lighting setting of each luminaire 101a, 101b may be varied based on the density of luminaires around the source. In this example, the variation can be:
In other words, if there are for example three luminaires within range of a source, the first, second, and third luminaires will adopt slightly altered versions of the source color. In the example formulation given above, the more densely the area is populated with lights, the more variation of colors exhibited by the luminaires.
The virtual locations of the virtual objects 4 are specified in data object 210, along with the influence value of each virtual object 4. A light effect is also associated with each virtual object 4. In this example, each virtual object 4 is associated with a different color. This is also shown diagrammatically in
The physical locations of the luminaires 101 are specified in the infrastructure map 212 as shown in
Luminaire D does not fall within range of any virtual source. In these cases (when a luminaire 101 is not affected by any virtual source 4), the luminaire 101 will not adopt any state (i.e. it will be in the OFF state), or alternatively be set to a default state (which could be the OFF state, but may also be an ON state such as a low brightness value on a default color).
In
A simple example is shown in
Mixing colors in the manner described above in relation to
In a first example, as shown in
Similarly, the amount by which a luminaire 101 is within the respective influence range of a source 4 can be used (the highest being the winner). In this case, luminaire A has a distance of 0.5 to source S1 and a distance of 0.3 to source S2 and therefore luminaire A will adopt the settings of source S1, because it is 0.25 (=0.75−0.50) within the influence range of source S1, and 0.0 (0.30−0.30) within that of source S2. Even though the light point is closer to source S2, it is still attracted to the state of source S1.
This can still result in conflicts in cases where a luminaire 101 is within range of two sources 4 by the same amount. For example, if the distance of source 2 would be reduced to 0.05, both would attract Light point A with 0.25. In a second example, as shown in
The rang-based tie break method of
The methods described herein can be extended to dynamic lighting scenes (i.e. lighting scenes which not only specify lighting settings for luminaires 101 in the physical space 201 but also specify temporal changes to those lighting settings).
In these cases, the data object additionally specifies one or more motion parameters which determine a motion of each virtual object through the virtual space. Thus, as the controller 400 applies the lighting script, the virtual objects' locations within the physical space will vary over time and thus which luminaires 101 are within range of each virtual source 4 will also change over time, thus rendering a dynamic lighting effect. The methods may also be applied to compensate for dynamic effects. For example, one of the luminaires 101 that are closer to the source 4 may be more ‘responsive’ to dynamic setting changes, whereas other ones of the luminaires 101 further away from the source 4 respond slower and more fluently to changes on light states. That is, the function defines a variation in at least one timing parameter of dynamics.
The function may also specify an amount of time for which a given lighting setting is to be rendered by the luminaire 101.
The function may also specify a rendering mode for the luminaire 101.
Further, it is appreciated that the influence range has been described with reference only to a circular (in 2D) or spherical (in 3D) influence range, wherein the influence value is a single (scalar) number indicating the radius of the influence range, but other shapes (volumes) are possible. For example, squares (cubes), rectangles (cuboids) or ellipses (spheroids) may allow more freedom to the lighting script designer. Examples are shown in
It will be appreciated that the above embodiments have been described only by way of example. Other variations to the disclosed embodiments can be understood and effected by those skilled in the art in practicing the claimed invention, from a study of the drawings, the disclosure, and the appended claims. In the claims, the word “comprising” does not exclude other elements or steps, and the indefinite article “a” or “an” does not exclude a plurality. A single processor or other unit may fulfil the functions of several items recited in the claims. The mere fact that certain measures are recited in mutually different dependent claims does not indicate that a combination of these measures cannot be used to advantage. A computer program may be stored and/or distributed on a suitable medium, such as an optical storage medium or a solid-state medium supplied together with or as part of other hardware, but may also be distributed in other forms, such as via the Internet or other wired or wireless telecommunication systems. Any reference signs in the claims should not be construed as limiting the scope.
Number | Date | Country | Kind |
---|---|---|---|
17150227.1 | Jan 2017 | EP | regional |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2017/082903 | 12/14/2017 | WO | 00 |