This invention relates to stage lighting and is particularly concerned with the control of multiple functions of a lamp.
It has already been proposed to incorporate in a lamp unit a plurality of different functions, such as colour changers, focusing lenses, iris diaphragms, gobo selectors and pan and tilt mechanisms which are controlled from a remote console. Stage lighting systems have as a result reached very high levels of complexity requiring a very complicated main control console and lamp unit constructions. The use of microprocessors, both in the console and the lamps bas become conventional as increasing complexity makes it more difficult to produce and subsequently maintain a system which uses hard wired logic or analog controls. In such systems the microprocessor in the console is used to allow the user to set up lighting cues and to control the sending of appropriate data to the lamp microprocessors. The lamp microprocessors are also involved in controlling communication between the console and the lamps, and also have to control a plurality of serve motors which drive the various functions of the lamps.
It is one object of the present invention to provide a lamp micro-processor and servo-control arrangement which allows complex functions to be carried out.
It is another object of the invention to provide a lamp control system in which control of pan and tilt movements of each lamp can be carried out in rapid and efficient manner, enabling large groups of lamps to make coordinated movements.
It is yet another object of the invention to provide each lamp in a stage lighting system with a means for quickly interrupting its light beam and quickly re-establishing the beam so that a group of lamps can be made, when required to flash in synchronism.
In accordance with one aspect of the invention there is provided a lamp unit for connection to a remote control console for the control of a plurality of different functions of the lamp, said unit comprising a main processor circuit, associated with a communication controller for accepting message data from the console, a plurality of servo-controls for operating said functions of the lamp, and a plurality of co-processors which are connected to the main processor circuit so as to be supplied thereby with desired value data for the various lamp functions, said servo-controls being controlled by said co-processors.
In the case of pan and tilt controls where close control is required throughout the movement of the lamp from an initial position to a new position, one of the co-processors is assigned solely to the control of movement about each axis. Other functions can share a co-processor.
The main processor circuit of the lamp is preferably programmed to accept data from the control console defining not only a target position for any function, but also a duration over which the function is to be executed. In this case the main processor circuit divides the “journey” into segments and updates the target position data passed to the associated co-processor at intervals.
In accordance with another aspect of the invention, there is provided a lighting control apparatus comprising the combination of a main control console for accepting user input relating to required beam movements, a plurality of independently operable lamp units situated remotely from the console, each of the lamp units incorporating a servo-mechanism for automatically moving the lamp beam about two mutually transverse axes to a desired angular position and data communication means connecting the console to the lamp units for the transmission of desired position data to the lamp units, the desired position data being transmitted in the form of a set of three dimensional linear co-ordinates defining a point in space through which the lamp beam is required to pass, and each lamp unit including a calculating device for calculating the desired angular position from the desired position data and supplying the servomechanism with such desired angular position.
In addition to the “point at” mode of operation mentioned above, additional modes may be specified in which the lamps point away from the specified point or in which they all point in the same direction parallel to a line between a fixed position in the co-ordinate system and the specified point.
Conveniently, all the data concerning the positions and orientations of the individual lamp units within the co-ordinate system is stored in a set-up file kept on a hard disk drive in the console. When the same lighting set-up is used at different venues, where it is impossible to set the frame which carries all the lamp units at exactly the same position as that for which the set-up was designed, offset data can be input at the console and either used within the console microcomputer to correct the position data stored during set-up as it is sent out, or such data can be sent to all or the lamp units over the network and stored there, to enable the corrections to be made in the individual lamp processor units.
In accordance with another aspect of the invention, a stage lighting unit comprises a housing, a light source within said housing, an optical system for forming light from said light source into a beam, a rotary shutter device having a plurality of blades, said shutter device being rotatably mounted in the housing so as to cause said blades to pass through and obstruct said beam as the shutter device rotates, a motor for rotating said shutter device and a servo-control for controlling said motor in accordance with data received in use from a remote control console.
The invention also resides in a stage lighting system incorporating a plurality of lighting units as defined above controlled by a common remote control console via data communication means, whereby the rotary shutter devices of all the units can operate in synchronism.
An example of the invention will now be described with reference to the accompanying drawings, in which:
FIGS. 4 to 7 are detailed circuit diagrams showing a rotary shutter motor drive control forming part of the internal circuitry of the lamp;
Referring firstly to
The console unit 10 has an array of switches, slider potentiometers, rotary digital encoders and other user actuable input devices (not shown) and a display indicated at 13. These are all connected to main console cpu 14 (an MC68020 micro-processor) which has the task of receiving inputs from the user actuable input devices and controlling the display. Both tasks are assisted by separate co-processors which directly interface with different parts of the console.
The main cpu can communicate with a hard disk drive unit 15 via a SCSI bus 16 which also connects it to the distribution unit and to an external SCSI port 17, through the intermediary of which the console can, if required be connected to a personal computer. The user controls can be used in setting up a sequence of cues in advance of a performance, the sequence being stored in a cue file on the hard disk drive unit 15. The sequence can be recalled during the performance to enable the various stored cues to be executed. Direct manual control of the lamps from the console is also possible as is manual editing of cues called up from the hard disk. The main console cpu 14 creates messages to be sent to the individual lamps, each message comprising a fixed number of bytes for each lamp. The messages contain data relating to the required lamp orientation, beam coloration, iris diaphragm diameter, gobo selection and rotation, zoom projection lens control and opening or closing of a shutter included in the lamp. A block of the RAM of the main cpu is set aside for the storage of these messages, the block being large enough to contain messages for 240 lamps, being the largest number which can be controlled via the distribution unit. Where it is required to control more than 240 lamps additional distribution units can be connected to the SCSI bus and extra main cpu RAM reserved for message storage. When any message data is changed the main cpu 14 sets a flag in the RAM block which is detected at a given point in the main cpu program loop and interpreted as a signal that the changed message data is to be transferred to the distribution unit 11.
The distribution unit 11 has a main cpu 19 which controls reception of data from the SCSI bus interface and distribution of such data to up to eight blocks of dual, port memory DP1, DP2, DP3 . . . via an eight bit data bus 20. The cpu 19 is alerted to the waiting message data when cpu 14 selects the distribution unit. The cpu 19 then supervises byte by byte transfer of the message data which it routes to the various blocks of dual port memory.
For actually sending out the message data to the lamps, there are a plurality of serial communication controllers SCC1 to SCC30, SCC31 to SCC60 etc, there being thirty serial communication controllers associated with each block of dual port memory. A further cpu DCPU1, DCPU2, etc is associated with each block of dual port memory and distributes message data transferred to the dual port memory to the individual serial communication controllers and the messages are transferred to the lamps. Each serial communication controller in the distribution unit includes a line driver which can be disabled except when data is to be transmitted. Enabling of the driver can cause a spurious signal to be transmitted over the data link. To allow such spurious signals to be identified and ignored, a two-byte gap is left between enabling the line driver and commencing transmission of the message data for the channel in question.
This will be described in more detail herein. All asynchronous serial communication systems require framing information to synchronize the reception process. This has been typically done in the prior art using start bits and stop bits.
The present invention preferably uses FMO coding in which the data is transmitted as one cycle of the carrier frequency for a zero or as a half cycle of the carrier frequency for a one. When the line has been idle, no waveform at all is present. When the line drivers are first enabled, an arbitrarily short pulse will usually appear on the line, due to lack of synchronization between the data signal and the enabling signal. This short data pulse could be misinterpreted as a start bit, for example and if so it would disturb later framing.
The present invention avoids any problems from this arbitrarily short pulse. To avoid this, the present invention uses a timer on the receive line, set to the time needed to receive two bytes on the serial data line. This timer is restarted whenever a byte on the data line is detected.
Each time the timer interrupt occurs, the number of bytes received is checked against the number of bytes in a valid data frame. If the number is incorrect, then the count is cleared and the message is discarded. If correct, the information is passed to the main program loop by setting a flag variable.
When the data line is first enabled, the distribution box has an internal delay of at least two byte times, which must elapse before any data will be sent. Any data received by the lamp will therefore be discarded as noise by the timer interrupt routine. After that, the real data can be safely sent down the line since the start bit of the first byte will be received correctly. When the transmission is completed, the line drivers will be disabled again.
Each of the cpus eg DCPU1, transfers data from the associated dual port RAM DP1 to the serial communication controller SCC1 to SCC30 with which it is associated one byte at a time, ie the first byte for SCC1 is transferred followed by the first byte for SCC2 and so on, each serial communication controller commencing transmission as soon as it has received its byte of data. The serial communication controllers operate to transmit data at 230.4 Kbps so that it takes about 35 μs to transmit each byte. Transfer of data from the dual port RAM DP1 to the serial communication controllers is, however, at a rate of several Mbps, so that the transmissions from all the serial communication controllers are almost simultaneous. The cpu DCPU1 is not required to monitor the transmission of data by the serial communication controller, but utilizes a software timer to commence transfer of the second byte to the serial communication controllers. This timer is started when transfer of the byte of data to the last serial communication controller SCC30 has been completed and its time-out duration is slightly longer than the byte transmission time, say 40 μs. Transmission of all the messages takes about 1.5 ms out of a distribution unit main program loop duration of 4 ms.
As shown in
The cpu 21 operates in accordance with programs stored in the lamp cpu ROM. On receipt of a message of valid length, a program variable representing the number of messages received since the lamp program was last started is incremented and the main program loop of the lamp cpu checks this variable every 16 mS. If the variable has changed since the last check, the data in the receive buffer is compared with corresponding values of variables representing current “desired values” of the various lamp function parameters. For example the receive buffer may contain two bytes representing the x, y and z co-ordinates of a point in an orthogonal three dimensional frame of reference, through which point it is required that the axis of the lamp beam should be directed. If the values of the corresponding byte pairs in the receive buffer and the desired value variables already contained in the cpu RAM are the same, no action is taken in respect of the control of the motors which control pan and tilt action of the lamp (to be described in more detail hereinafter).
As shown in
Before proceeding with a more detailed description of the circuitry and operation of the lamp electronics, some detail will be given of the various functions of the lamp.
As shown in
Referring now to
Turning now to
The two FETs Q3 and Q4 are connected to the return bus via a current sensing resister RC, which supplies a current related signal to a voltage comparator 45 with hysteresis to provide an input to the A6 input terminal of the co-processor 26 when the current exceeds a predetermined limit. This enables the co-processor to reduce the power applied to the motor to maintain it within safe operating limits.
The optical encoder of the pan motor provides two digital outputs in quadrature, these outputs being cleaned up by interface circuits and applied to two inputs of an HCTL-2016 counter ic 46 intended specifically for use with quadrature type encoders. The counter 46 counts up when the pulses are in one relative phase relationship and down when the opposite phase relationship exists. It therefore maintains a count-state related to the motor shaft position and hence the pan angle of the lamp. This count-state is applied to the C0 to C7 terminals of the coprocessor 26. The co-processor 26 also receives “desired value” data from the main lamp cpu 21, via a 75176 ic 47 (which in fact serves both co-processors 26 and 27). The ic 47 is used to control the transmission or data between the main lamp cpu and the co-processors. Normally the ic 47 is set to receive data from the cpu 21 and pass it to the two co-processors 26 and 27. At power-up or when the main lamp cpu 21 transmits a “break” command, the coprocessor 26 is reset by a circuit 48. The co-processor 26 has a cycle time of 1 mS and on receipt of new data it determines the distance to be travelled and then increases the “desired position” value which is compared with the actual position count by one sixteenth of the required change on each successive iteration of its control loop.
The desired value signals passed from the cpu 21 to the co-processor 26 are also time-sliced, being incremented every 16 mS. When new position data is transmitted to the lamp it is accompanied by data representing the length of time over which the movement is to be spread. The data is received, as mentioned above, in the form of two byte numbers respectively representing the x, y and z co-ordinates of a point in a Cartesian co-ordinate system. During initial setting up of the system, each lamp is sent data which informs its cpu 21 of its position in the co-ordinate system and also of its orientation.
On receipt of a new set of “point at” co-ordinates, the cpu 21 undertakes a “time-slicing” operation to determine how data should be passed to the co-processors 26 and 27. First of all, it determines how many 16 mS loops will take place in the time duration determined by the data contained in the massage received by the lamp and sets up a variable U equal to the reciprocal of this number. A travel variable P is initialised to zero and the total distance to be travelled is determined for each of the pan and tilt movements. Thereafter, on every iteration of the 16 mS loop the travel variable P is incremented by the reciprocal variable U, the result is multiplied by the total travel required and this is added to (or subtracted from) the previous desired value before transmission to the co-processor 26 or 27. When the variable P exceeds unity, the target has been reached.
The message sent to the lamp may include a flag indicating whether travel is to occur in a linear fashion as described above or have a sinusoidal profile imposed on it. In the latter case the value of P is modified as follows:
P′=sin(2*P)+0.5*(P>0.5) the latter term being 0 or 1
The main cpu 26 must next convert the x, y, z values into pan and tilt value data for passing to the co-processors 26 and 27. The cpu first carries out a linear transformation of the absolute x, y, z co-ordinates into co-ordinates x′,y′,z′ relative to the lamp's own frame of reference using the data supplied during initial set up. The ratio of the transformed x′ and y′ values is calculated as a 16-bit integer, which is used as an index to an ARCTAN table stored in ROM to obtain a value for the desired pan angle. To find the tilt angle, it is first necessary to establish the radial position of the target point in the transformed horizontal plane by calculating the square root of the sum of the squares of the co-ordinates x′ and y′. In carrying out this calculation it is necessary to detect an overflow condition which exists if the sum of the squares is a 33 bit number. If this condition is detected, each square is divided by four and a new sum is formed, an overflow flag being set to indicate that overflow has occurred. The square root is found by up to sixteen steps of successive approximation and the result is doubled if the overflow flag was set during the calculation. The resulting square root is divided by the value z′ and the result is applied as before to the ARCTAN table to determine the tilt angle. The results obtained represent the new pan and tilt positions to which the lamp is to be moved.
The arrangement described for sending out x, y and z co-ordinate data instead of pan and tilt angle data is highly advantageous in that it enables the console main cpu load to be significantly reduced and also makes it very easy for a console operator to control light beam movements. It is frequently required for a group of lamps to be used together to illuminate a single performer. Where the performer moves from one position on stage to another it is required for all the lamps to change position simultaneously to follow. If the system involved transmission of pan and tilt angle data, this data would be different for every lamp in the group. It would have to be set up by the console operator and stored in cue files on the hard disk drive unit 15. This would be a very time consuming operation as the pan and tilt angles for each lamp would have to be established and recorded individually. The cue record would need to be of considerable size to record all the different data for each lamp. With the arrangement described above, however, only the x, y, z co-ordinate data needs to be stored and when the cue is recalled the same data is sent to each of the lamps in the group.
Whilst it is theoretically possible to use stored cue data in x, y, z co-ordinate form and to use the console main cpu 14 to calculate the pan and tilt angles to send to the lamps, this would be unsatisfactory as the calculations involved would impose a very heavy load on the cpu 14, particularly where a large number of lamps in several different groups had to be moved as the result of a single cue.
As described above a “point-at” mode is envisaged as the normal operating mode. However, other modes of operation are also envisaged. For example, the lamp could be instructed to point away from the point specified or to point in a direction parallel to a line joining a fixed point (eg the origin of the co-ordinate system) to the point specified. These “point-away” and “point parallel” modes would be selected by means of flags included in the data transmitted to the lamps.
The arrangement described enables the lamps to be very precisely synchronised. The data is transmitted from the distribution unit to all of the lamps simultaneously and each lamp can start to respond at the end of the message. This enables very precise direction of all the lamps to a moving point in “point-at” mode and very clean parallel sweeps to be made in “point parallel” mode.
It should be noted that the use of x, y, z co-ordinates is also very advantageous in situations where a prearranged lighting performance is to be used in several different venues. The pre-loaded gantries or trusses used for such touring performances cannot always be mounted at exactly the required positions relative to the stage because of local conditions. In this case all that is needed is for offsets data to be sent to the lamps at set-up time to enable each lamp cpu to correct its position data. No editing of the individual pre-recorded cues is necessary as it would be in the same circumstances if pan and tilt data were stored.
As part of the set-up procedure for each performance it is necessary to initialise the values of the actual pan and tilt angle count-states, since encoders of the type used do not give any absolute position data. This is accomplished by driving the lamp to an end stop in one direction for each movement. The lamp is driven back to a predetermined number or counts and the counters are reset to zero at this position.
Turning now to FIGS. 5 to 7, the circuitry for controlling the individual dc servo-motors inside the lamp is more complex as each co-processor has to deal with up to six servo-motors. As shown in
As co-processor 28 has only 256 bytes of internal memory, extra memory is required for each channel to store program variables. The RAM selection control circuit is shown in
Circuit 57 actually controls the motor current, but it in turn is controlled by a pulse width modulator circuit, comprising the latch 58 and a digital comparator 65 which compares the contents of latch 58 with the count-state of an 8-bit continuously running counter 66a, 66b serving all channels. The comparator output goes high when the count-state exceeds the latch contents, so that if the latch content is low the comparator output is high for a high proportion of each cycle of the counter 66a, 66b. The output of the comparator 65 is ANDed with an enable output from ic 56 by a gate 67 and then with the output of an overcurrent detector circuit 68 by another gate 69.
When a new target value for one of the parameters controlled by co-processor 58 arrives in the receive buffer, and it is associated with execution duration data (this may apply to lens movements, colour changer movements, gobo movements and iris diaphragm movements, but not shutter movements) the cpu 21 handles time slicing as in the pan and tilt operations. Since several channels are controlled by each co-processor, however, no interpolation by the coprocessor is used. Instead each channel has its error checked and a new value written (if necessary) to latch 58 every 12 mS.
In the case of the shutter, the message received by the lamp merely includes a shutter open or shutter closed command. When the required shutter status changes, the main cpu merely increases the target shutter angle by 45 degrees (in the case of a four bladed shutter) and passes the new value to the co-processor.
This arrangement enables the shutters of some or all of the lamps to be operated in synchronism. Moreover, the console cpu 14, can operate to update the shutter open/closed instructions at regular intervals to obtain a stroboscopic effect, synchronised for all the lights.
Number | Date | Country | Kind |
---|---|---|---|
9220303.3 | Sep 1992 | GB | national |
9220309.0 | Sep 1992 | GB | national |
9308071.1 | Apr 1993 | GB | national |
This application is a divisional application of and claims priority to U.S. patent application Ser. No. 11/127,975, filed May 11, 2005; which is a continuation of U.S. patent application Ser. No. 10/625,465, filed Jul. 22, 2003, now U.S. Pat. No. 6,894,443; which is a continuation of U.S. patent application Ser. No. 10/007,008, filed Dec. 4, 2001, now U.S. Pat. No. 6,597,132; which is a continuation of U.S. patent application Ser. No. 09/313,418, filed May 17, 1999, now U.S. Pat. No. 6,326,741; which is a divisional of U.S. patent application Ser. No. 08/994,036, filed Dec. 18, 1997, now U.S. Pat. No. 5,921,659; which is a continuation of U.S. patent application Ser. No. 08/576,211, filed Dec. 21, 1995, now U.S. Pat. No. 5,788,365; which is a divisional of U.S. patent application Ser. No. 08/077,877, filed Jun. 18, 1993, now U.S. Pat. No. 5,502,627; which claims the benefit of Great Britain Application Serial No. 9220303.3, filed Sep. 25, 1992, Great Britain Application Serial No. 9220309.0, filed Sep. 25, 1992, and Great Britain Application Serial No. 9308071.1, filed Apr. 20, 1993. The disclosures of the prior applications are considered part of (and are incorporated by reference in) the disclosure of this application.
Number | Date | Country | |
---|---|---|---|
Parent | 11127975 | May 2005 | US |
Child | 11857404 | Sep 2007 | US |
Parent | 08994036 | Dec 1997 | US |
Child | 09313418 | May 1999 | US |
Parent | 08077877 | Jun 1993 | US |
Child | 08576211 | Dec 1995 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10625465 | Jul 2003 | US |
Child | 11127975 | May 2005 | US |
Parent | 10007008 | Dec 2001 | US |
Child | 10625465 | Jul 2003 | US |
Parent | 09313418 | May 1999 | US |
Child | 10007008 | Dec 2001 | US |
Parent | 08576211 | Dec 1995 | US |
Child | 08994036 | Dec 1997 | US |