The present invention relates to the creation of aerial messages, and more specifically, relates to systems and methods for controlling and coordinating the creation of aerial messages using a plurality of aircraft.
Skywriting, one of the oldest methods of creating aerial messages, is the process by which a single aircraft emits a continuous or nearly continuous biodegradable vapor trail while twisting and turning to “write” each letter in the sky. The aerial messages produced by skywriting, which are capable of being seen from the ground for many square miles, provide a dramatic way for companies to advertise their products or services. However, the popularity of wide-spread skywriting is limited by several factors, including the risks involved in making the aerobatic twists and turns inherent in skywriting, the high degree of aviator skill required to make such precise maneuvers, and the substantial costs in creating even short aerial messages. Additionally, the length of aerial messages created using skywriting techniques is limited because strong winds may blur or dissipate the beginning letters of a long message before the aviator can make all of the twists and turns necessary to complete the message, thereby lessening the otherwise dramatic effect of the aerial message.
To improve the feasibility and ease of creating aerial messages, aviators began using multiple aircraft flying in formation to create messages, with each aircraft emitting short “puffs” of vapor or smoke in a defined pattern to form the individual characters (e.g., letters, numbers, etc.) of the messages. The resulting messages, which are created within a single pass, look like the printouts from a low resolution dot-matrix printer, with individual characters being formed by a pattern of vapor puffs that resembles the pattern of ink dots produced on paper by a dot-matrix printer. Thus, rather than “writing” aerial messages using only a single aircraft, the messages are “printed” in the sky using five or more aircraft, with each aircraft contributing a portion of each character. In order to accomplish the coordination necessary between the multiple aircraft, a master or lead aircraft uses a transmitting device to transmit a plurality of discrete tones or radio signals to the remaining (i.e., receiving) aircraft. These receiving or slave aircraft emit vapor puffs in response to the radio signals received from the master aircraft.
Although an improvement over traditional skywriting techniques, several problems are commonly encountered by existing systems. For example, in order to rearrange two slave aircraft into different positions in a flight formation, existing systems require that the pilots of the two aircraft mutually agree via their radio system to switch positions and then physically adjust their respective receivers to receive the signal originally intended for the other aircraft. Additionally, because the receiving units in each slave aircraft are configured to receive discrete radio frequencies, the units are not easily interchangeable into other slave aircraft.
The present invention provides systems and methods for the creation of aerial messages using multiple aircraft, where each aircraft emits discrete puffs of vapor to form portions of the aerial message. The resulting pattern of vapor puffs resemble the pattern of dots used by a dot matrix printer to print messages on paper. The invention includes the use of multiple computational devices to enable the coordination, control and printing of aerial messages. A main or master computational device is connected, via a physical or wireless network connection, to multiple control boxes (also computational devices) located in each aircraft. Each control box is connected to a vapor or smoke system installed in its respective aircraft, which allows the control boxes to control the emission of vapor puffs from the aircraft. Software running on the master computational device is used to coordinate the vapor puffs by sending data to and receiving data from each of the control boxes.
Several benefits are obtained by the present systems and methods. For example, real-time bi-directional communication between the master computational device and each of the control boxes allow the user of the computational device to better coordinate and control the creation of the aerial message. Thus, the user of the master computational device is informed when one of the aircraft has veered out of formation and is no longer receiving data, thereby either producing misaligned vapor puffs or no vapor puffs at all. Additionally, because it is beneficial for the master pilot to know which aircraft are running low on vapor material in order to coordinate the switching of aircraft to different positions in the flight formation (allowing the aircraft with the most vapor material to be moved to positions requiring the most vapor puffs), the systems and methods provide a direct means for informing the master pilot of the vapor material levels in each slave aircraft.
Additional benefits are obtained in that the systems and methods provide an intuitive graphical user interface for easily and quickly creating multiple aerial messages, allowing a user of the master computational device to dynamically alter the aerial message and/or the message parameters (for example, message speed, width of each character, etc.) during flight. In addition, maintenance and repair of the control boxes is facilitated by the solid state design of the control boxes. The control boxes may also be easily interchanged between aircraft with minimum alteration.
A system for creating aerial messages using a plurality of aircraft. The system includes a logic and processing unit configured to provide a user interface for creating aerial messages using a plurality of aircraft, wherein the logic and processing unit is located in a master aircraft and sends data to and receives data from a master controller, and a master controller located in the master aircraft, wherein the master controller is a node on a wireless local area network (LAN) and is configured to transmit data over the LAN to a plurality of slave controllers and to receive data from each of the plurality of slave controllers. The system further includes a plurality of slave controllers located in a plurality of slave aircraft, wherein each of the plurality of slave controllers is a node on the wireless LAN and is configured to receive data from and transmit data to the master controller, and a plurality of vapor puff creation systems located in the master aircraft and in each slave aircraft.
A method for producing aerial messages. The method comprises transmitting puff data from a computer to a plurality of controllers located in a plurality of aircraft, the puff data including an indication of when each of the plurality of aircraft is to emit a vapor puff, and receiving status data at the computer from each of the plurality of controllers, the status data indicating whether the vapor puff was emitted by each of the plurality of aircraft.
A method for producing aerial message using a plurality of aircraft. The method comprises analyzing an aerial message to determine which of a plurality of aircraft should produce a vapor puff in order to form a portion of the aerial message, and transmitting data packets addressed to a controller located in each of the plurality of aircraft instructing when the aircraft should emit vapor puffs, wherein each of the data packets is transmitted over a wireless LAN to the controller.
A system for producing aerial messages using a plurality of aircraft. The system comprises a main computer configured to provide a user interface for use in producing aerial messages using a plurality of aircraft, wherein the main computer operates as a node on a wireless network to transmit data to and receive data from a plurality of controllers located in a plurality of aircraft, a plurality of controllers located in a plurality of aircraft, wherein each of the plurality of controllers is a node on the wireless network and wherein each of the plurality of controllers is configured to process data received from the main computer. The system further comprises a plurality of vapor puff creation systems located each of the plurality of aircraft.
A control box for controlling the emission of vapor material from an aircraft. The control box comprises a transceiver for transmitting data to and receiving data from one or more nodes on a wireless network, the received data including an indication of when an aircraft is to produce a vapor emission, and an antenna connected to the transceiver for use in transmitting and receiving the data from the one or more nodes on the wireless network. The control box further comprises a processor for processing the data received by the transceiver, the processor including firmware for determining from the received data when the aircraft is to produce the vapor emission, a first relay capable of activating a vapor pump in response to a signal from the processor, and a second relay for opening a solenoid valve in response to a signal from the processor.
A system for creating aerial messages. The system comprises a graphical user interface configured to display one or more screens, wherein a user employs the displayed screens to create an aerial message, a calculation module configured to calculate a number of vapor puffs required by one or more aircraft in creating the aerial message, and a database configured to store the aerial message. The system further comprises a data packet generation module configured to generate data packets including portions of the aerial message, and a simulation module configured to graphically simulate the creation of the aerial message.
A data format stored in a computer readable medium. The data format comprises a puff data portion including an indication of whether the particular aircraft is to produce a vapor puff, a duration measurement portion including a measurement for how wide to make the vapor puff, and a time delay measurement portion including a measurement for how long to wait before creating the vapor puff.
A data format stored in a computer readable medium. The data format comprises an internet protocol (IP) address portion including an address associated with a particular node on a wireless network, a vapor level data indicator portion including an indicator that data pertaining to a measurement of vapor material remaining in a tank of a particular aircraft is being sent in a data packet, and a vapor level data portion including the measurement of how much vapor material remains in the tank of the particular aircraft.
A method for simulating the creation of an aerial message. The method comprises providing a plurality of physical aircraft, providing a plurality of graphical images representative of the physical aircraft, and correlating each of the plurality of graphical images to one of the plurality of physical aircraft, wherein each of the plurality of graphical images display a vapor puff graphic at the same time as its corresponding physical aircraft emits a vapor puff.
A method of composing an aerial message. The method comprises displaying a first screen containing one or more characters of an aerial message, wherein a user selects one or more characters to compose the aerial message, and in response to the user specifying an option to save the composed aerial message, creating an aerial message file, wherein the aerial message file includes a binary representation of the composed aerial message.
A method of creating an aerial message file using a plurality of aircraft. The method comprises receiving an aerial message from a user, wherein the received aerial message includes one or more potions and wherein the received aerial message is used to create an aerial message file, and opening an output file. The method further comprises for each portion of the aerial message, scanning one or more data files for data corresponding to the portion, wherein the corresponding data is copied to the open output file; for each aircraft, calculating a number of vapor puffs required by the aircraft to produce the aerial message, wherein the number of vapor puffs required is copied to the open output file; and closing the output file, wherein the output file is the aerial message file.
A method for repositioning aircraft in a formation of multiple aircraft. The method comprises providing a network address to each of a plurality of aircraft, wherein the network address uniquely identifies each of the plurality of aircraft on a network, and providing an identifier specifying a position of each of the plurality of aircraft in a flight formation. The method further comprises, in response to a user selecting an option from a main computer to switch the positions of two or more of the plurality of aircraft, redirecting data packets to the two or more of the plurality of aircraft based on a new position of the two or more aircraft in the flight formation, wherein the data packets are redirected without requiring pilots of the two or more of the plurality of aircraft to alter any settings in the two or more of the plurality of aircraft.
A method of forming characters for an aerial message. The method comprises providing an option for a user to specify a pattern of vapor puffs, wherein the specified pattern of vapor puffs forms a desired character, receiving the pattern of vapor puffs specified by the user, and translating the received pattern of vapor puffs to a binary representation of the desired character.
A method for displaying images on a vapor screen. The method comprises determining a predefined area for an aerial vapor screen, and using software for controlling vapor emissions from a plurality of aircraft, creating an aerial vapor screen. The method further comprises projecting images onto the aerial vapor screen.
A system for composing and displaying aerial messages. The system comprises a first software module configured to permit a user of the software to compose an aerial message, and a second software module configured to coordinate the display of the aerial message.
A method for producing aerial messages. The method comprises transmitting data from a first processing unit to a plurality of controllers located in a plurality of aircraft, wherein the plurality of controllers each include a second processing unit, and receiving data at the first processing unit from each of the plurality of controllers, the received data being responsive to the data transmitted by the first processing unit.
These and other features of the invention will now be described with reference to the drawings. These drawings and the associated description are provided to illustrate preferred embodiments of the invention, and not to limit the scope of the invention.
Throughout the drawings, reference numbers are re-used to indicate correspondence between referenced elements. In addition, the first digit of each three-digit reference number and the first two digits of each four-digit reference number indicate the figure in which the element first appears.
Systems and methods representing several embodiments and an example application of the invention will now be described with reference to the drawings. In one disclosed embodiment, the systems and methods provide for the creation of an aerial message using multiple aircraft, where each aircraft emits discrete puffs of vapor or smoke to form individual characters of the aerial message, much like the discrete ink dots used by a dot matrix printer to print characters on paper. The aerial message may include, for example, but is not limited to, text messages, alphanumeric messages, Internet addresses, graphical images, symbols, and/or logos. For convenience only, and not by way of limitation, an aerial message may also be referred to herein as a skyboard.
The systems and methods may be implemented in a variety of embodiments. In one embodiment, the aerial message is “printed” using a plurality of aircraft piloted by on-board human operators. The aerial message may be printed in any orientation, include, for example, forward and backwards printing (for example, printing the aerial message “Hello” beginning either with the “H” or the “O”). Generally, one of the aircraft is designated as a master or lead aircraft and the remaining aircraft are called slave or non-lead aircraft. The master aircraft generally flies in the center position of the aircraft formation. However, the master aircraft may alternatively be located in any other position in the aircraft formation. In another embodiment, remote controlled devices, such as special-purpose remote controlled planes or drones, may be used to create (or print) the aerial message. The remote controlled devices may be commanded or piloted from a ground control station. In other embodiments, a combination of human operated aircraft and remote controlled aircraft may be used to print the aerial messages. In this dual embodiment, the master aircraft may be piloted by a human operator with the slave aircraft being remotely controlled from the master aircraft or from a ground control station.
Aerial message may be created during the daylight hours or at nighttime. In the embodiment in which messages are created after sundown, spotlights or other lighting systems are used to illuminate the aerial messages, allowing viewers from the ground to see the night aerial messages.
It will be recognized that many of the various process steps described herein are performed by or using software executed by one or more general-purpose computers, although the process steps could alternatively be embodied in-whole or in-part within special purpose hardware or firmware.
These and other features will now be described with reference to the drawings summarized above. The drawings and the associated descriptions are provided to illustrate embodiments of the invention, including various implementation-specific details of these embodiments, and not to limit the scope of the invention. The scope of the invention is set forth in the appended claims.
I. Overview
The front aircraft may be on the left or the right of the flight formation. A V formation uses a front aircraft in the center of the formation with the remaining aircraft swept back from the front aircraft. The following depicts a V formation, as seen from an altitude above the aircraft:
The wedge formation is a modified V formation using two aircraft at the front of the formation with the remaining aircraft swept back behind the two front aircraft (rather than the traditional one front aircraft involved in a V formation). The following depicts a wedge formation, as seen from an altitude above the aircraft:
In other embodiments (not shown), the aircraft fly in a vertically descending echelon formation, printing the aerial message vertically at a much lower altitude than possible with horizontal aerial messages. In this embodiment, the aircraft are arranged in an echelon formation; however, each particular aircraft flies at a lower altitude (or different altitude) than the aircraft located in front of them in the formation. Thus, the aircraft are vertically stepped down, much like the steps of a staircase. Using the vertical format, aerial messages are printed at an altitude much closer to viewers located on the ground (for example, 2,000-3,000 feet), creating impressive, spectacular aerial messages. Alternatively, a vertically descending frontline formation may be used to create the aerial messages.
The present invention employs multiple computational devices (also known as processing and logic units) to enable the coordination, control and printing of aerial messages. In one embodiment, the master aircraft 102 employs a computational device for controlling the emission of vapor puffs by all of the aircraft. The computational device may be a laptop computer, palm device, personal digital assistant, or other such appropriate device. For convenience only, and not by way of limitation, the computational device will be referred to herein as the master computer. Using aerial message software running on the master computer located in the master aircraft, the pilot of the master aircraft may dynamically edit the message, alter message parameters, and/or modify aircraft and system settings. The pilot or other user of the aerial message software may interact with the software via voice recognition methods, a touch screen, a mouse device, keyboard, and/or other such appropriate interface devices.
The master computer is connected, via a network connection, such as, for example, an Ethernet connection, to a master or main control box located in the master aircraft. In other embodiments, the master computer communicates with the master control box via a wireless network connection. The master computer also communicates, via the master control box, with slave control boxes located in each of the slave aircraft 104. Each of the control boxes (master and slave) is connected to a vapor or smoke system installed in the aircraft, which allows the control boxes to control the emission of vapor puffs from their respective aircraft.
Alternatively, the master computer communicates with all of the control boxes (both master and slave) directly via a wireless network connection. In yet other embodiments, the communication control and vapor emissions of all of the aircraft (including the master aircraft) are controlled by a master computer located remotely from the aircraft, such as, for example, at a ground control station. In this embodiment, the control boxes of all of the aircraft (master and slave) may be identical, thereby eliminating any special functionality previously associated with the master control box. Using this embodiment, multiple ground control stations may be used to control the production of multiple aerial messages by the same fleet of aircraft. For example, the aircraft may produce an aerial message over a beach party with a ground control station located on the beach, and then fly inland to an air show to produce an aerial message with a ground control station located at the air show. In this embodiment, the aerial message software running at each ground control station connects to each aircraft (via the control boxes in each aircraft) when the aircraft are within range of the ground control station. The connection between the ground control station and the aircraft may be setup to occur manually or automatically.
Although
Two fleets of aircraft may be used to create the lines of the aerial message at the same time, with one fleet printing “HELLO” and the second fleet printing “WORLD !” If the fleets print the message while flying in opposite directions, the first characters created may appear as follows to a viewer on the ground:
Thus, each fleet prints a line of the aerial message at approximately the same time. The second characters being created in opposite directions would appear as follows to a viewer on the ground:
The process continues until the aerial message is completed. In the alternative, one fleet of aircraft may print the message on multiple lines by either using additional aircraft in a single fleet or by turning the fleet around to print each subsequent line of the aerial message. In the embodiment in which the fleet turns around to create subsequent message lines, it may be particularly useful to alter flight formations since some of the aircraft may make the turns in less time than other aircraft in the formation. For example, if the first message line is created using a line abreast formation, the second message line may be created with an echelon formation where aircraft 3 (as shown in
II. Aerial Message System Components
Although not shown, the front of the master control box 402, in one embodiment, resembles the front of the slave control box 302, including each of the same LEDs. On the master control box 402, however, the linked LED indicates when the master control box 402 is receiving packets from or sending packets to the master computer 404 (see
The processor 414, the central processing unit of the master control box 402, connects to two solid-state relays 416 and 418. Using firmware (not shown) programmed into flash read-only memory (ROM) on the processor 414, the data packets addressed to the master control box 402 are processed by the processor 414, which activates the relays 416, 418 as appropriate. The Relay 416 is connected to a pump 422. The pump 422 is also connected to a tank 420 of vapor material, such as a lightweight vegetable oil. In one embodiment, the vapor material in the tank 420 may be colored using dyes to produce colored vapor puffs (such as red, blue, green, etc.) when heated, thereby allowing for the creation of colored aerial messages. For more detail on the use of colored vapor material, please see section VII below.
When activated by the processor 414 (by, for example, a 5 volt current), relay 416 turns the pump on, thereby allowing a build up of vapor pressure to be generated in the vapor system. The tank 420 is also connected to the processor 414. A sensor 430 on the tank measures the amount of vapor material remaining in the tank and transmits such information to the processor 414. Using the program stored in flash ROM (also referred to as firmware), the processor 414 then forwards the vapor material measurements of the tank to the aerial message software running on the master computer 404. Relay 418 is connected to a solenoid value 424, which, in turn, is connected to the pump 422. When activated by the processor 414, relay 418 opens the solenoid value, allowing the vapor material to enter the aircraft engine exhaust 428. As it enters the engine exhaust 428, the vapor material is heated and emitted from the aircraft exhaust system as visible vapor or smoke. The vapor material may be introduced into the exhaust system 428 via a small hole drilled into the exhaust system (see
Upon receiving an instruction from the master computer 404, via the hub 408, to switch on the electric pump 422, the processor 414 activates relay 416 (for example, through a 5 volt signal sent to the relay through resistor R6). In response, relay 416 sends a signal to activate the pump 422 (for example, using a 12 volt signal), and, at the same time, activates the pump LED 520 using a current supplied through resistor R4. After the pump 422 is switched on, the processor 414 activates relay 418 (for example, through a 5 volt signal sent to the relay through resistor R7). In response, relay 418 signals the solenoid value 424 to open by supplying an electric current to the value 424 for a specified time period, thereby allowing for the emission of vapor material through the engine exhaust 428. Relays 416, 418 may be, in one embodiment, a Philips ECG Solid State Relay. During the time in which the solenoid value 424 is open, the vapor LED 522 is activated through a current supplied through resistor R5. Relay 418 is additionally connected to a solenoid surge suppressor 512 to minimize any damage likely to be caused by transient voltages. The ready LED 516 and the linked LED 518 are activated by the processor 414 via an electric current supplied through resistors R2 and R3, respectively.
In another embodiment (not shown), the master computer 404 communicates directly with the control box located in each of the aircraft (including the master aircraft), rather than use a master control box 402 to transmit packets to the slave control boxes 302. In this embodiment, the control box in each aircraft, including the master or lead aircraft 102, is identical to the slave control box 302 depicted in
III. Aerial Message Software System
As used herein, the word module refers to logic embodied in hardware or firmware, or to a collection of software instructions, possibly having entry and exit points, written in a programming language, such as, for example, C++ or Visual Basic. A software module may be compiled and linked into an executable program, or installed in a dynamic link library, or may be written in an interpretive language such as BASIC. It will be appreciated that software modules may be callable from other modules or from themselves, and/or may be invoked in response to detected events or interrupts. Software instructions may be embedded in firmware, such as an EPROM or EEPROM. It will be further appreciated that hardware modules may be comprised of connected logic units, such as gates and flip-flops, and/or may be comprised of programmable units, such as programmable gate arrays or processors. The modules described herein are preferably implemented as software modules, but may be represented in hardware or firmware.
It is contemplated that the modules may be integrated into a fewer number of modules. One module may also be separated into multiple modules. The described modules may be implemented as hardware, software, firmware or any combination thereof. Although, the modules are preferably located in the master computer 404, the described modules may alternatively reside at different locations connected through the network.
A. Graphical User Interface
The graphical user interface 804 (GUI) provides easy to use graphical screens for composing an aerial message, printing an aerial message, and creating a character library. The GUI also interacts with the simulation module 810 to provide detailed real-time feedback on the actual printing process. Additionally, the graphical user interface 804 provides access to a database system 812, including data on the number of messages printing and aircraft and system parameters. A user of the aerial message software interacts with the GUI using a mouse, touch screen, keyboard, or other such interface device.
B. Calculation Module
The calculation module 806 performs various calculation steps involved in composing and printing an aerial message, including calculating the number of puffs required by each aircraft to produce a particular aerial message and correlating data received by the aerial software from the slave control box 302 indicating the amount of vapor material remaining in each slave aircraft. The calculation module 806 converts the received data into a numerical value, which is displayed using the graphical user interface 804.
C. Data Packet Generation Module
The data packet generation module 808 generates data packets for transmission on the wireless network by gathering data from the calculation module 806 and the graphical user interface 804. Both the master control box 402 and the slave control box 302 transmit and receive data packets. Data packets are generated by the data packet generation module, which is distributed between the aerial message software and the control boxes, at intermittent times, such as, for example, every 2-3 seconds. With an average packet size of 10-12 Kb, the data packets may be transmitted frequently without slowing down the network. For more information on the sample file and data packet formats for the aerial message system, please refer to the section below entitled “Sample Data Format”, which describes
D. Simulation Module
The simulation module 810 controls a simulation of the aircraft and vapor generation during printing of the aerial message, which is displayed in the simulation window 1504 (see
E. Database System
The database system 812 includes a graphic files database 820, a character library database 822, an aircraft profile/system database 824, and a message/mission database 826. The graphic files database 820 includes a graphical image of each character. The graphical image is displayed above selectable icons on the compose message screen 1102 (see
Although the above-described databases have been discussed as individual databases, it is to be understood that the particular databases may be included in one database or may be divided into additional database. The databases, although preferably located on the master computer, may alternatively in-whole or in-part be distributed across a network.
F. Compose Message Process
The compose message process 814 creates an aerial message file 1402 (see
G. Print Message Process
The print message process 816 prints an aerial message from the aerial message file 1402. For a detailed description of the print message process 816, please refer to the section entitled “Print a Message” below.
H. Character Creation Process
The character creation process 818 creates new library character using an input grid 2308 (see
IV. Sample Data Format
IP ADDRESS+PUFF DATA PORTION+DURATION MEASUREMENT+TIME DELAY MEASUREMENT=PUFF DATA FORMAT.
In one embodiment, the puff data portion 902 is generated by the data packet generation module 808 according to the methods described below, and includes an indicator of whether the particular slave aircraft 104 being sent the puff data packet 900 is to produce a vapor puff. The indicator may be any indicator capable of representing a puff status and a no puff status. For example, in one embodiment, a “1” is transmitted as the puff data portion if the slave aircraft 104 is to emit a vapor puff and a “0” is transmitted as the puff data portion if the slave aircraft 104 is not to emit a vapor puff. The duration measurement 904, which may be determined substantially real-time by the calculation module 806, provides information about the width of the puff to be created by the particular slave aircraft 104. The time delay measurement 906 is also generated by the calculation module 806, and allows for a time delay between receipt of the puff data packet 900 by the slave control box 302 and generation of a vapor puff. The time delay measurement 904 is altered depending on the particular flight formation being used to create the message, and the particular position 204 of the slave aircraft 104 in the flight formation. The position 204 becomes more important in non-line abreast formations, such as with an echelon or V formation. The IP address 916 indicates where to send the data format 900.
IP ADDRESS+VAPOR LEVEL DATA INDICATOR+VAPOR LEVEL DATA PORTION=VAPOR LEVEL DATA FORMAT.
In one embodiment, the vapor level data indicator 910 is an indicator that the data packet being sent contains data about the level of vapor material in a particular slave aircraft 104. The vapor level data portion 912 contains an actual measurement value for the amount of vapor material remaining in the tank of the slave aircraft. The IP address 916 indicates where to send the data format 908.
Several additional data formats are transmitted by either the master control box 402 or the slave control box 302. In addition to the puff data format, the master control box 402 generates and sends packets to determine whether a slave aircraft is still actively on the network. If no response is received to the transmitted data packet within a specified time period, the pilot of the master aircraft 102 is notified of the non-responding slave, and the aerial message software attempts to auto-reconnect with the non-responsive slave aircraft 104. The master control box 402 may also send a data packet querying the slave control box 302 to determine the amount of vapor material remaining in the tank of the slave aircraft 104. For additional details on the process of determining the amount of vapor material remaining in each tank, please see section VII.B below. Additionally, the aerial message software running on the master computer 404 (via the hub 408) sends data packets to the control boxes 302, 402 signaling the control boxes to turn the pumps 616, 422 on and off. Thus, the aerial message software may, in one embodiment, automatically control the electric pumps 422, 616 with minimum interaction by the pilot of each aircraft. Turning the pumps 616, 422 off when not in active use printing aerial messages minimizes the risk (due to the constant pressurized vapor material in the line between the pump 422, 616 and the solenoid valve 424, 618) of a high-pressure explosion and reduces wear and tear on the parts of the pumps 616, 422.
In addition to the vapor level data format 908, the slave control box 302 also generates and sends confirmation data packets confirming that the slave control box 302 turned the pump 616 on or off and that the slave aircraft made a puff as instructed by the master control box 402. In one embodiment, the confirmation data packet transmitted back to the master control box 402 by the slave control box 302 is an echo (or a duplicate) of the message originally sent by the master control box 402. If the slave aircraft 104 is still within range, the slave control box 302 also responds to data packets from the master control box 402 querying to find out whether the slave control box 302 is active and responding on the network.
Although the discussion of this section has referred to the master control box 402 sending data packets to the slave control boxes 602, it is to be understood that the data packets are often, although not always, generated by the aerial message software running on the master computer 404. It is also understood that the master control box 402 receives and transmits the same data packets as described for the slave control boxes 602. Thus, for example, the aerial message software sends a puff data packet to the master control box 402 in order to generate a vapor puff by the master aircraft 102. Likewise, the master control box 402 generates a confirmation data pack back to the aerial message software once a vapor puff has been created.
V. Aerial Message Software Methods
By providing a flexible and user-friendly graphical user interface (GUI), the aerial message software allows a user to easily design and store a virtually unlimited number of characters, which may be readily assembled into aerial messages or skyboards using a character library. A collection of skyboards may also be assembled together to create a “mission”. A mission includes multiple skyboards to be printed at various locations for one or more clients. By collating multiple skyboards into one mission, the pilot of the master aircraft need only load one file containing all of the skyboards to be created during the flight. The aerial message software automatically pauses after completion of each skyboard and waits for the user to select (for example, using a mouse, touch screen or voice recognition software) an option to print the next skyboard. Thus, the aircraft can fly between various locations printing multiple skyboards without loading additional files.
The software additionally provides a GUI from which a user may control the production of vapor puffs for all aircraft in the flight formation. By real-time accounting for aircraft speed, puff length and aircraft formation, the software allows aerial messages to be printed with almost any aircraft at almost any speed and altitude. The bi-directional communication also provides real-time data regarding the amount of vapor material remaining in each aircraft, allowing a user of the software to readily determine when to switch aircraft between different formation positions so as to maximize vapor usage and reduce the chance that one aircraft will run out of vapor material before the end of an aerial message or mission.
A. Composing an Aerial Message
A user composes an aerial message using the aerial message software running on the master computer 404. A GUI and related software methods involved in composing an aerial message will now be described with reference to
1. Graphical User Interface
A character may be any letter, number, punctuation mark, accent mark, symbol, graphic, image, picture or other mark normally used in printed communication. By selecting each character (for example, via clicking a button, pushing a key, speaking a sound, etc.), the user enters an aerial message into the message window 1106. The user alters the spacing between characters by selecting or otherwise entering a number into the font spacing box 1108 and selecting an option 1110 to insert a space. The spacing may be altered between characters on a character-by-character basis to create messages having more or less spaces between various characters or portions of the aerial message. In one embodiment, a default spacing of 12 is inserted between each character unless the user alters the spacing. For more detailed information on the spacing between characters, please see section V.A.2, entitled “Composing Methods”, below. As illustrated by the compose message screen 1102, the standard English library may include additional symbol or marks, such as dashes, dots, exclamation points or apostrophes.
The user may also load different character libraries by selecting an option 1114 to change the current library. In response to selection of the change library option 1114, a pop-up screen (not shown) is displayed listed all currently defined libraries. The defined libraries may include, for example, English, French, Spanish, Japanese and so forth. Libraries may also be created according to various themes, such as, for example, a holiday library (with holiday messages and graphics) or a natural disaster awareness library (with emergency instruction messages). The GUI and methods additionally allow the user to toggle between existing libraries when creating an aerial message, forming messages with characters from one or more languages. For example, by typing or otherwise entering an English phrase, toggling to the Spanish library and entering a Spanish phrase, and toggling back to the English library to finish the message with another English phrase, the user may create a dual language aerial messages, such as, for example, “Visit Mi Casa Mexican Restaurant!” Stylization fonts, such as italics, bold or even underlining, may also be produced using the disclosed methods for composing an aerial message. For example, to produce italics fonts, a user creates italicized characters using the character library features (see section V.C below) or alters the time delay measurement for the aircraft (see section IV above and section V.B.2 below) in order to slant the characters of the aerial message. To produce bold fonts, in one embodiment, the duration measurement (see section IV above) is altered to keep the solenoid valve 424, 618 open longer, thereby creating a denser vapor puff. After the user has completed the message, the user selects an option 1116 to name and save the file.
Missions, which are discussed above, are created by selecting an option 1122 to join multiple aerial messages into a single mission file (not shown). If a library includes more characters than possible to fit comfortably on the compose message screen 1102, the user may review all of the library characters by selecting an option 1118 to review additional library characters not displayed on the current screen.
2. Composing Methods
One embodiment of the software methods relating to composing and saving an aerial message will now be described in further detail with reference to
Beginning in state 1208 and continuing through state 1216, each character in the aerial message is analyzed to determine a corresponding vapor puff pattern for the given character. In state 1210, the appropriate library file 1302 (see
Pilots generally view characters along a flight line or path used in creating the characters, which is referred to herein as an aerial view. The aerial view of the same L character is achieved by taking the mirror image of the ground view and rotating the image 90° counterclockwise. For example, the mirror image of the above shown L character is shown as follows:
Next, to visualize the aerial view, the above shown mirror image is rotated 90° counterclockwise, which produces the following aerial view of the L character:
In this example, the required vapor puff pattern corresponds to the pattern of 1's seen above. Filling the empty positions in with 0's to represent the condition where no vapor puff is to be generated and separating the puff/no puff data with commas to allow for computer processing, the resulting vapor puff pattern becomes:
Thus, the data organization for each character in the aerial message file (see
Thus, for example, in parsing for the vapor puff pattern corresponding to an “L” character in the English library, the process scans the English library file 1302 for all puff data lines beginning with an “L” character and extracts these puff data lines (for example, the four lines shown above). Once the corresponding lines of puff data (also referred to as the character data) are extracted from the library file 1302, the data is saved in state 1212 (
In one embodiment, the puff data is inserted into the aerial message file 1402 in a specific order; thus, the character symbol is unnecessary and not copied into the new file 1402. Alternatively, it will be understood by those in the relevant art that any binary representation may be used to represent the vapor puff patterns. For messages incorporating characters from multiple languages, the methods determine the appropriate library file (based on a unique library file identifier associated with each character in the message received in state 1204), check the library file and extract the corresponding puff data.
The process next determines in state 1214 the user-specified (or default) spacing between the current character and the next character and inserts spacing data 1404 (see
B. Printing an Aerial Message
A user (master pilot or ground control user) controls the printing of the aerial message using the aerial message software running on the master computer 404. The graphical user interface and related methods involved in printing an aerial message will now be described with reference to
1. Graphical User Interface
From the main menu screen (
An indication of the number of vapor puffs required to print the “Hello” message is displayed in box 1514. As indicated by box 1514 in
The print message screen 1502 also includes information about the number of puffs remaining in each aircraft 1518, the number of messages printed during a flight 1528, and the speed for printing the aerial message 1530. The box 1518 associated with a particular aircraft, in one embodiment, decrements for each vapor puff created by the particular aircraft. In another embodiment, the puffs remaining is determined using the sensors on the vapor tanks in each aircraft 102, 104, where the control box of each aircraft transmits vapor level data to the aerial message software. A user may also alter the width of the vapor puffs (and thus the characters) being created for each aircraft on an aircraft-by-aircraft basis using a selectable width parameter 1532 or collectively for all aircraft at once using a global width parameter 1534. By allowing for the width of the vapor puffs to be altered on an aircraft-by-aircraft basis, the methods compensate for different vapor densities generally produced by different aircraft types/models. Thus, the methods provide greater flexibility in creating uniform vapor puffs even though different models of aircraft may be used within a single aircraft formation. The user is also provided an advance option 1538 to advance (or forward) the message to some intermediate point in the message. Printing of the message, if started, then begins at the intermediate point to which the message was advanced. A reset option 1540 is provided to reset the message to its starting point.
Before printing the aerial message, the user enables each of the aircraft by selecting a setup option 1520. Enabling the aircraft ensures that each of the aircraft is able to communicate with the aerial message software and receive instructions from the aerial message software system by establishing an open socket with each aircraft. Once enabled, a visual indicator appears on the print message screen 1502 indicating that each aircraft is properly enabled (that the socket was successfully established). In one embodiment, the visual indication is a green highlight outlining the “ON” graphic 1522 for each aircraft. A disabled aircraft displays an “OFF” graphic 1522 (only shown with “ON” indicator). Alternatively, in another embodiment, the aerial message system performs an automatic connection/enabling process without any specific action being taken by the user. Data is transmitted to a particular enabled aircraft by writing the data to the socket established with that aircraft. Thus, for example, if five aircraft are enabled, five sockets are opened by the aerial message software, one socket with each aircraft.
After the aircraft are enabled, the user begins printing the message by selecting a start option 1542. Printing may be stopped at any time by selecting a stop option 1544. As shown in
Because each graphic 1546 corresponds in real-time to its associated physical aircraft 102, 104, a user may watch the miniature aircraft 1546 in simulation window 1504 to determine whether the vapor puffs actually being produced by the physical aircraft 102, 104 are properly timed so that each aircraft is producing a vapor puff in correct alignment, thereby reducing the need to visually spot the actual aircraft to determine whether the vapor puffs are properly aligned. The real-time simulation feature greatly enhances a user's ability to easily detect and correct formation and/or system problems, especially when flying in formations for which it is difficult or even impossible for a master pilot to monitor the actual flight of the aircraft. Additionally, as a secondary visual clue, the vapor puff images highlight or alter colors as they reach the nose of the miniature aircraft 1546.
Another feature of the print message screen 1502 is the current aircraft identifies box 1524, which identifies what aircraft are located in what position 204 in the flight formation. Thus, as depicted in
Additionally, the aerial message software provides notification to a user of the software when an aircraft is out-of-range and no longer receiving network signals. In one embodiment, data packets are generated on a regular schedule (such as every second or every three seconds) to query each slave control box to determine whether the control box is receiving the data packets. Upon receiving the data packets, each slave control box 602 “echoes” the data packet back to the aerial message software running on the master computer 404, thereby informing the aerial message software that the slave control box 602 is still in range and receiving network traffic. In the embodiment in which the master computer 404 is located at a ground control station, the aerial message software likewise queries (monitors) the master control box to determine whether the master control box is still in range and receiving data packets from the aerial message software. In the alternative, a global positioning system (GPS) tracks the location of each aircraft and its position in the flight formation, and provides the basis for the out-of-range determination and notification.
If the aerial message software does not receive a echo response from a particular slave control box 602 within a prescribed time period, the software notifies the user that the slave control box 602 is out-of-range. The notification is provided using various indicators, such as, for example, an audible indication to the user that an aircraft is out-of-range. In other embodiments, the particular aircraft graphic 1546 associated with the non-responsive aircraft changes color (for example, the graphic turns red), an indicator mark (for example, an exclamation point or asterisk) is displayed next to the aircraft graphic 1546, and/or the graphic 1522 displays an “OFF” indication (rather than the “ON” graphic shown in
Several other features are also accessible from the print message screen 1502. The streak 1-5 feature 1548 allows the user to streak (i.e., simultaneously signal for vapor emissions) from all aircraft to test whether each aircraft is receiving packets correctly and producing vapor. The user may also get statistics on the system by selecting the statistics option 1550. A statistics pop-up box 2102 is displayed that informs the user the number and name of each message loaded and completed, the number of puffs actually remaining in each aircraft, the total puffs required for a message, and the number of puffs completed.
2. Printing Methods
One embodiment of the printing process will now be described in further detail with reference to
Beginning with states 2210, for each row of character data in the aerial message file 1402 the process continues to state 2211 in which the character speed 1530 is read from the display screen 1506. In state 2213, a row clock is set to a value associated with the character speed determined in state 2211. Beginning in state 2212, for each aircraft 102, 104 the printing process and data packet generation module 808 create a data packet, in state 2214, including an indication of whether the aircraft is to emit a vapor puff, a specified duration for the vapor puff and any needed time delay between the slave control box 602 receiving the data packet and emitting the vapor puff.
In one embodiment, the time delay (between a slave aircraft receiving a data packet and sending a signal to open the solenoid valve) is based on each aircraft's position in the flight formation and/or the particular flight formation being used, and is dynamically read from the aerial message software each time a data packet is created. For example, if the aircraft are flying in a line abreast formation, the only time delay necessary is associated with the amount of time it takes the aerial message software to generate and send data packets to each of the aircraft. In the line abreast example, the following time delays operate to form aligned vapor puffs:
Thus, the time delay associated with the data packet sent to the aircraft in formation position 5 is 300 milliseconds, the time delay sent to the aircraft in formation position 4 is 200 milliseconds, and so forth. As illustrated by this example embodiment, a time period of approximately 300 milliseconds elapses from sending the first data packet to sending the last data pack for each character data row. This time delay operates as a default time delay associated with the speed of processing each row of character data.
In the example embodiment in which the aircraft fly in a V formation, an additional time delay associated with the V formation is generated using various algebraic relationships and known variables. For example, using a V formation with each aircraft having a lateral distance between the aircraft of 200 feet and a sweep back angle of 15°, the formation is depicted as follows:
In the depicted illustration, angle A denotes the sweep back position of aircraft 2 (and aircraft 4) and “a” denotes the lateral distance between aircraft 1 and aircraft 2. Side “b” denotes the fore/aft distance of aircraft 2 from aircraft 1. In order to create substantially aligned vapor puffs, if aircraft 1 creates a vapor puff at a given time, aircraft 2 waits until it is substantially aligned with the vapor puff created by aircraft 1 before producing a vapor puff. Knowing the airspeed of aircraft 2, the lateral distance between aircraft, and the sweep back angle, the aerial message dynamically determines the distance b and the time required for aircraft 2 to travel distance b, using the following formulas:
b2=c2−a2
Alternatively, the time delay value is set to a default value in the aircraft profile database 824, and may be altered using profile screen 2602 (see
The process determines in state 2220 whether the process has reached the end of the character data row. Each row of the aerial message file 1402 is referred to as a character data row. If the end of the row has not been reached, the process proceeds to state 2221, in which the next aircraft data (the next column in the row) is read and then states 2214-2220 are repeated for that aircraft. If, in state 2220, the end of the character data row has been reached, the process proceeds to state 2222 in which the process determines whether the row clock has expired. If not, the process waits until the row clock expires before proceeding to state 2224. If the row clock has expired and the aircraft clocks (the ones associate with each graphic 1546) have expired, in state 2224, a graphic of a vapor puff is displayed for the duration specified in the original data packet sent to each aircraft. After the smoke is displayed, the master computer time delay clock for each aircraft graphic is reset in the master software in state 2226. In state 2228, the graphical representation 1612 of the aerial message is advanced in the simulation window 1504 as the next character data row of the aerial message data file 1402 is read. In state 2232, the process determines whether the end of the aerial message file 1402 has been reached. If the end of the message is reached in state 2232, the aerial message is reset in state 2236 and the process proceeds to an end state 2238. Otherwise, the process moves to the next row in state 2234 and states 2212-2232 are repeated for the next character data row until the end of the aerial message file 1402 is reached. In one embodiment (not shown), prior to proceeding to the end state 2238, the process sends a signal to each of the control boxes 402, 302 instructing the respective control boxes to turn off the pumps 422, 616.
C. Creating a Character Library
The user interface and related methods involved in creating a character library will now be described with reference to
1. Graphical User Interface
A user may create characters that are not already part of an existing character library, such as a graphical image or business logo using the character library option 1008 from the main menu (
2. Character Creation Methods
One embodiment of a character creation process will now be described in further detail with reference to
D. Additional Software Features
Several additional features are provided by the aerial message software.
Additionally, a security feature is provided in which the aerial message software is operable only when activated with a system security file (not shown). The system security file is associated only with a specific component of the system hardware, such as, for example, a unique identifier of a hard drive located in the master computer. Because the aerial message software requires the system security file before loading the software, unauthorized copies of the software are inoperable. The system security file may be configured to provide access to the aerial message software for a specified time duration (such as, for example, a month) or for a specified number of aerial messages (such as, for example, up to 12 aerial messages).
A tracking and accounting feature is provided which allows an administrator to remotely monitor aircraft fleets established throughout the United States or in various countries around the world, with the master computer of each fleet (or group) maintaining an aerial message log. After completion of an aerial message, the methods and systems update the message log stored on the master computer with information pertaining to each aerial message created. Using remote access or other methods, the administrator or another user is able to upload a message log file (not shown) to a central computer system. Using the message log file, an administrator of the central computer system is able to determine information pertaining to each aerial message, such as, for example, the contents of a printed aerial message, the date and time the message was printed, and/or the location (for example, using a GPS receiver) where the aerial message was printed. Alternatively, the master computer may be connected to the World Wide Web via a wireless connection and transmit such message log information to a central computer (or a server) each time an aerial message is printed or each time the printing of an aerial message is initiated. A report may be generated from the message log detailing the information contained in the message log. The tracking and accounting feature thereby provides a convenient way to determine fees for potential licensees or clients. Additionally, the administrator may troubleshoot systems remotely or view system/aircraft parameters.
VI. Operation
An example of the systems and methods in operation will now be described in which a user of the master computer desires to create an aerial message reading “HELLO.” Using the compose message screen, the user types or otherwise enters the message “HELLO” into the message window and selects an option to save the aerial message, naming the message “hello.stm.” The software generates an aerial message file as discussed above (see
To print the aerial message, the user goes to the message printing screen and loads the “hello.stm” file into the aerial message software. Once the user has selected an option to load the “hello.stm” file, a graphical representation of the “HELLO” message is displayed in a simulation window. The displayed graphical representation in the simulation depicts the message in an aerial view format. The user next enables all of the aircraft in the formation, which establishes an open socket with each aircraft. After the user selects a start printing option, the aerial message software begins generating and transmitting data packets to each of the aircraft. The data packets include an IP address of the aircraft to which the data packet is directed, an indication of whether to create a vapor puff, a time delay measurement, and a duration measurement.
For example, to create the line of vapor puffs corresponding to the first character data row of the aerial message file including “HELLO,” the process reads the data in the first character row, which appears as follows:
Before reading the value in the first column, the aerial message software sets a row clock to a character speed value specified by the user. The row clock is used to determine how fast the aerial message software reads each row of character data. After setting the row clock, the software reads the value in the first column. Because there is a “1” in the first column of the first row, the process knows to send an indication to aircraft 5 to make a vapor puff. In our example, (see
The time delay measurement is determined based on the aircraft speed, the lateral distance between aircraft, and the sweep back angle of the flight formation. Thus, if the user desires to fly in a V formation, the user sets the system settings using the system setting option from the main menu screen of the aerial message software. Suppose, for example, the user decides to fly with a sweep back angle of 15 degrees and with a lateral distance of 200 feet. The user then enters the sweep back angle, lateral distance and airspeed into the aerial message software (see
Thus, using the quadratic formula b2=c2−a 2, the computer determines that b is equal to the following value:
b=sqrt[(200 feet/cosine 15)2−(200 feet)2]
If the airspeed of the aircraft in feet/second is 528,000 feet/3600 sec (also 200 miles/hour), the software uses the formula t=b/r to determine that the time for aircraft 2 to travel distance b is as follows:
Thus, the delay value (to one decimal point) transmitted by the aerial message software to aircraft 2 is t+50 ms, which equals a total time delay value of 86.4 ms. The time delay for each aircraft is calculated using the same formula and the constant time delay corresponding to each aircraft position. For example, the time delay associated with aircraft 5 is 72.8 ms+300 ms, which equals 372.8 ms.
Therefore, for example, the aerial message software sends a data packet to aircraft 5 with the following format and data:
This informs aircraft 5 to make a vapor puff 372.8 ms after receiving the data packet. A clock in aircraft 5 begins a countdown from 372.8 ms, and when the clock reaches zero, the solenoid valve is opened for 1 second. At the same time that the data packet is sent to aircraft 5, a clock in the aerial message software, which is associated with a graphical representation of aircraft 5, also begins a countdown from 372.8 ms. When the associated graphical clock reaches zero, the graphic of aircraft 5 displays a vapor puff trailing from the graphical representation for 1 second. Thus, the graphical representation of each aircraft is synchronized with the actual physical aircraft.
This process continues for each column in the first character data row. Once the process reaches the end of the first character data row, the process waits until the row clock reaches zero, and then proceeds to the second character data row. The faster the character speed set by the user, the shorter the wait between processing character data rows. In other words, there is an approximately linear relationship between character speed and the speed at which the aerial message software reads each row of character data. When the process proceeds to the second character data row, the software resets the row clock to a value associated with the currently specified character speed, and advances the simulated aerial message in the simulation window of the message printing screen. The software also resets the clocks associated with the graphical representations of each aircraft. The process is then repeated for each row until the end of the aerial message file is reached and the aerial message has been printed.
VII. Alternative Embodiments
As indicated above, the disclosed systems and methods are useful in a variety of embodiments. In one embodiment, black and white images, such as, for example, black and white photographs, are created using lighter and darker vapor puffs. As illustrated in
In yet further embodiments (see
VIII. Conclusion
Although this invention has been described in terms of certain preferred embodiments, other embodiments that are apparent to those of ordinary skill in the art, including embodiments that do not provide all of the benefits and features set forth herein, are also within the scope of this invention. It will also be understand by one of skill in the art that the flow charts provided herein are for illustrative purposes only, and that various states of the flow charts may be interchanged and still retain the inventiveness of the present invention. Accordingly, the scope of the present invention is defined only by reference to the appended claims.
This application is a divisional of U.S. patent application Ser. No. 09/874,565, filed on Jun. 5, 2001, titled “Systems and Methods for Creating Aerial Messages”, the entirety of which is hereby incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 09874565 | Jun 2001 | US |
Child | 11285602 | Nov 2005 | US |