Sensor and controller for wind instruments

Abstract
This invention involves the field of tactile control of electronic devices using a sensor that transduces both air pressure and device positional orientation into a set of digitally encoded commands. The invention involves using as input the physical action taken on a musical instrument and generating control information using that input.
Description
FIELD OF INVENTION

This invention involves the field of tactile control of electronic devices using a sensor that transduces both air pressure and device positional orientation into a set of digitally encoded commands. The invention involves using as input the physical action taken on a musical instrument and generating control information using that input.


BACKGROUND

In the past, musical instruments have been used to record audio signals into recording devices. However, a musical instrument involves more than just notes. Playing a wind instrument, like clarinet, involves using air pressure, delivered by the musician's mouth, into the mouthpiece, where a reed resonates. When a musician seeks to play louder, say during a crescendo, the musician blows harder into the instrument. In a wind instrument, the air pressure in the mouth is increased as a result. In addition, musician's express themselves through movement of the instrument while playing. While playing, the musician may move the distal end of the instrument up and down, or from side to side. The air pressure and movement of the instrument can be utilized as additional forms of instrumental control by use of the invention. This is accomplished by using sensors that detect these changes, convert these changes into encoded data and then use this encoded data to generate other controller commands ranging from modifications of an audio signal to controlling stage lighting.





BRIEF DESCRIPTION OF THE FIGURES


FIG. 1 shows a side view of the SMS Sensor module of the invention attached to a wind instrument mouthpiece



FIG. 2 shows a side view of the SMS Sensor module of the invention attached to the mouthpiece of a wind instrument



FIG. 3 shows the basic system architecture



FIG. 4 shows the SMS sensor housing



FIG. 5 shows the SMS remote housing



FIG. 6 shows a representation of an “airplane” style display showing the detected orientation of the musical instrument.



FIG. 7 shows a representation of a “joystick” style display showing the detected orientation of the musical instrument.





DETAILED DESCRIPTION

Various examples of the invention will now be described. The following description provides specific details for a thorough understanding and enabling description of these examples. One skilled in the relevant art will understand, however, that the invention may be practiced without many of these details. Likewise, one skilled in the relevant art will also understand that the invention can include many other features not described in detail herein. Additionally, some well-known structures or functions may not be shown or described in detail below, so as to avoid unnecessarily obscuring the relevant description. The terminology used below is to be interpreted in its broadest reasonable manner, even though it is being used in conjunction with a detailed description of certain specific examples of the invention. Indeed, certain terms may even be emphasized below; however, any terminology intended to be interpreted in any restricted manner will be overtly and specifically defined as such in this Detailed Description section.


There are three modules that make up the sensing system: The SMS Sensor, SMS Remote and SMS monitor software, that operates on an external computer. In one embodiment of the invention, a sensor circuit is contained within a sensor housing that comprising the SMS Sensor. This device may be mounted on the wind instrument in the region of the mouthpiece. The sensor housing has a pipe emanating from it that leads to the mouthpiece of the instrument. The sensor housing is comprised of an air pressure sensor. FIG. 1 and FIG. 2 show side views of the mouthpiece of a reed musical instrument, that is, clarinet or saxophone etc. The thin end on the left is inserted into the players mouth. The right side begins he throat of the instrument. The reed is 104/204. 105/205 is the prior art metal strap that holds reed to the bottom of the mouthpiece. 106/206 shows the beginning of the throat of the instrument. Item 102/202 is a hollow flexible tube that feeds into the air pressure sensor device 101/201. There are two embodiments of the other end of the tube: In FIG. 2, 207 shows the tube going under the foam layer 203 and going into hollow section of the mouth piece along is surface. In FIG. 1, 107 shows the tube extending under the foam layer 103 all the way to the end such that the tube end would be in the musician's mouth region.


In the preferred embodiment, the SMS Sensor (101/201) is comprised of a solid state electronic device that converts air pressure into a signal, preferably a digital data signal, although in some embodiments, an analog output may be used. As the air pressure in the pipe changes, the air pressure at the sensor device comprising SMS Sensor (101) causes the digital values output from the sensor device to change. In one embodiment, a sensor is used that provides an absolute pressure measurement in the range of 10-1300 milli-bars. The SMS Sensor module is comprised of the sensor device that operatively connected to a microcontroller comprised of a central processing unit (CPU), a computer memory and a radio frequency data transceiver. The sensor device, memory and RF transceiver are addressable by the CPU using typical computer microprocessor design techniques such that the CPU can read and write data from these components in accordance with a processes running on the CPU as a program.


As the musician plays, the CPU in the SMS Sensor can poll the air pressure sensor to read and thereby capture and update data representing the air pressure in the musician's mouth region in near-real time. In addition, the SMS Sensor module can transmit this data stream to the external computer by writing the air pressure data into the communications unit. The communications unit can then transmit this data to the external computer. As an alternative embodiment, the process that reads the sensor may be interrupt driven rather than polled. In either case, the air pressure value is periodically read from the device and transmitted to the SMS Monitor processes running on an external computer.


In another embodiment, the position of the musical instrument itself can be detected. In this embodiment, the sensor housing contains a device that can detect the orientation of the musical instrument relative to the earth's magnetic field. In the preferred embodiment, the sensor housing contains a device that can detect its angular position relative to the earth's magnetic field using a magnetometer. The detection may be the relative angle between a fixed axis of the sensor and the local field lies of the earth's magnetic field. This information is accessible by the CPU by reading addressable registers where the current device orientation relative to the earth's magnetic field is presented. As the musician plays and moves around, that orientation data changes. The orientation data is typically encoding orientation along the horizontal plane. The CPU reads this data from the sensor registers and stores them in the computer memory. In addition, the CPU can write the data to the communications unit, which can then transmit the information to the external computer.


In another embodiment, the sensor housing comprising the SMS Sensor module (101) contains a device that can detect the elevation angle of the musical instrument. In the preferred embodiment, the sensor housing contains a device that can detect its angular position relative to the earth's gravitational field. The detection is the relative angle between a fixed axis of the sensor and the center of the earth's gravitational field, typically the center of the earth. This information is accessible by the CPU by reading addressable registers where the current device elevation is presented. As the musician plays and moves the instrument up and down, the elevation data changes. The elevation data is typically encoding elevation in a vertical plane, perpendicular to the horizontal plane. The CPU reads this data from the sensor registers and stores them in the computer memory. In addition, the CPU can write the data to the communications unit, which can then transmit the information to the external computer.


In yet another embodiment, an accelerometer sensor may be used within the SMS Sensor module (101). In this embodiment, the data generated by the accelerometer sensor represents the motion of the instrument and its direction relative the sensor axis. Some accelerometers output data representing movement in two dimensions and some in three. In the preferred embodiment, the accelerometer operates in three dimensions. Using this embodiment, an accelerometer sensor data stream may be used in place of an orientation sensor and elevation sensor. The accelerometer data stream may be utilized by the SMS Monitor to calculate the location of the instrument based on a series of motions starting at a calibration start point. The accelerometer data stream may represent a series of motion vectors, each vector representing a time slice. By numerical integration, a position vector may be calculated from a series of acceleration vectors. The resulting position vector will be a relative vector to the initialization position. The sum of both vectors will then be the absolute position and orientation of the instrument.


In yet another embodiment, the sensor in the SMS Sensor module may include a gyroscope sensor. This sensor can measure absolute direction orientation of the musical instrument relative to the gyroscope's nominal position. In this embodiment, the sensor data stream will provide data representing the orientation of the musical instrument. In yet another embodiment, the air pressure sensor, magnetic field sensor, gravitational field sensor and gyroscope sensor may all comprise the SMS Sensor, and further may all be part of the same solid state device housed within the SMS Sensor and addressed by the CPU.


In the preferred embodiment, the processed data of the sensors are scaled and offset so that for whatever maximum and minimum set positions or elevations, the range of output from the processor is from and including zero to one, or from minus one to plus one. This then avoids the problem that as the musician deals with specific contingencies from one venue to the next that the downstream uses of the data as it applies to audio signal processing or venue environment controls can remain the same.


Normalization involves calculating a linear function such that the incoming data is scaled so that the maximum incoming data value is converted to a predetermined maximum in the output range, and the minimum incoming data is converted to a predetermined minimum in the output range. The offset is a value added to the input data to accomplish the same purpose. The normalization function can be considered as:

Output value=(Input value plus Offset value) times Scaling Factor
Or
Output value=Offset value plus (Input value times Scaling Factor)


In some embodiments, the Scaling Factor itself may be a function of the input, in order to introduce logarithmic or exponential scaling:

Output value=Offset value plus (Scaling Factor times log(input value))
Or
Output value=Offset value plus (Scaling Factor times exp(exponent, input value))


The data collected by the SMS Sensor module is transmitted to the SMS Monitor module. This can be accomplished preferably using a Bluetooth™ network or any other data network. The data may include some or all of the sensor data described above. For example, use of an accelerometer and gyroscope may be sufficient. Conversely, use of a magnetometer and gravitational sensor may be sufficient. The SMS Monitor module processes the incoming data from the SMS Sensor module in order to prepare it for downstream use. In the case of the air pressure, the computer operates a process that normalizes the data, so that the range of input data from the musician is either scaled up or scaled down by a predetermined amount such that the output of the scaling has a range of values that are usable by downstream uses, described further below. In the preferred embodiment, the air pressure values are scaled to be between and including zero to ones. Further, an offset may be applied so that the ambient air pressure is set to be zero. This is applied to the data as it is flowing because the processed data output is then relayed through computer inter-process communication techniques to audio processing computer programs or performance environment controlling software, as further described below.


Similarly, the orientation and elevation data is preprocessed by the external computer comprising the SMS Monitor module by scaling in the same way. In the preferred embodiment, pre-processing is performed by the computer calculating a linear mathematical function on the incoming data with a pre-determined linear coefficient. In other embodiments, other mathematical functions may be used, for example, a logarithmic function that also has a linear coefficient.


In the case of orientation, the external computer first calibrates itself by setting a nominal orientation for the instrument. For example, the nominal orientation could be set for when the musician's instrument is pointing out from the stage, that is, the longitudinal axis of the instrument is perpendicular to the edge of the stage, or perpendicular to the rows of seating in a venue that a performance is occurring. This may represent the actual compass orientation of the instrument relative the earth's magnetic field. As the computer receives orientation values from the communication unit of the sensor housing, these actual values, which may represent compass angular values are then converted into angular values relative to the set nominal position, both positive and negative.


In another embodiment, the nominal position could be set to a left maximum or right maximum and the conversion to angular values relative to those nominal positions. In addition, the external computer can set a maximum stage left position and maximum stage right position. Then, the incoming actual compass values can be scaled so that for different venues, where motion of the musician may be constrained, the downstream uses of the data retain the same range of effect while using more constrained motion. In other words, the range of output of the scaling is the same, and the coefficient of the scaling is determined from the set maximum left and right positions. The relative orientation output is then relayed through computer inter-process communication techniques to audio processing computer programs or performance environment controlling software, as further described below.


The elevation sensor data may be scaled and calibrated similarly. The external computer can set a minimum elevation, for example when the musician holds the instrument pointing down at the lowest point the musician cares to select, and then the maximum elevation that the musician wants to point up. The external computer process can then scale the elevation data so that the output range is at its maximum and minimum using those to set positions.


The SMS Monitor processes can also manipulate the sensor data as follows:

    • Sampling rate multiplication by extrapolating continuous data. If the downstream applications require more granular measurements over the time axis, the SMS Monitor can extrapolate between two known measurements to estimate a measurement that is prior to the next polled data point. For example, of position is polled at zero and 10 milliseconds, but the downstream application wants values every 5 milliseconds, then the two measurements can be used to calculate a slope, and then the second measurement plus ½ times the slope will be the estimated value at 15 milliseconds.
    • Data priority hierarchy. If the downstream application has different priority needs for the data feeds, for example, audio processing being more important to be real time than stage lighting, then the data feeds from the sensors are processed and transmitted downstream with that priority.
    • Gesture detection. The data feeds from orientation, elevation and the accelerometer may be used to extract a general feature of movement that is recognizable by the computer. For example, the data may represent a motion of down and up on the left side, followed by a swing to the right. While every rendition of the gesture may result in data that is numerically different, the SMS Monitor can apply pattern recognition algorithms to detect a condition that such a gesture has occurred because the numerical data representing the measured gesture is sufficiently close to a pre-determined data pattern. This pattern recognition result can be converted by the computer process into a data message representing a command to be processed by the downstream system.


The SMS Monitor operating on the external computer presents the user a graphical user interface (GUI) on a display screen in order to permit the user to input by means of touch screen or other actuation device connected to the computer and select various parameters of operation. For example, the GUI may display a slider bar on a touchscreen attached to the computer that permits the user to select, by moving the bar on the touch screen, bar position and thereby select the scaling factor for the normalization process. Furthermore, the various scaling factors for the various sensors may be saved in a file on the SMS Monitor to permit these parameters to be recalled.


In one embodiment, the SMS Monitor presents an apparent 3 dimensional graphic on the display screen showing the apparent position of the musical instrument based on the sensor data as described above. In one embodiment, the display is presented as a “joystick”, (FIG. 7) where the rendering is a view of the instrument away from a geometric origin. As the orientation of the instrument is detected, the SMS Monitor uses the received positioning data to generate graphical primitives with geometric values that are calculated so that when displayed, shows the apparent orientation of the instrument in a predetermined orientation with respect to the plane of perception and orientation. Another embodiment is an “airplane” display, (FIG. 6) where the position of the instrument is shown as if looking down the axis of the instrument. In either case, This display can show the apparent orientation of the instrument as determined by the SMS Monitor, in order that scaling factors be selected. The SMS Monitor can select between displaying the raw position of the instrument and the normalized and offset position based on a selection by the user of a selection actuation on the GUI. Mapping parameters that adjust how the actual position of the instrument is applied to generate control data output can be also applied to adjust these graphical representations. For example, a scaling down of angular data may be used such that when the instrument is swept from +45 degrees to −45 degrees across a crowded stage, the display shows the instrument swinging side to side more widely, and therefore the control data being transmitted downstream encoding a narrow sweep of the instrument's position into a complete sweep for controlling the sound processing equipment.


Most importantly, the SMS Monitor permits the user to select output channels for the data, where the output channels provide the sensor data for controlling downstream audio equipment or stage show effects. In one embodiment, there is an audio to electrical signal converter, typically a microphone, (303) into which the instrument sound itself is converted to electrical signals. These signals can be converted to digital values representing the sound of the instrument. That digital data stream may be processed by a computer program operating various digital audio signal processing techniques, either in a stand-alone audio processing device (307) or within the external computer (304). The data stream may also be parsed and reformatted so that the data presentation is compatible with the downstream equipment communication and data processing protocols, that is, the downstream equipment receiving the data is detecting the data in a manner it expects so that the equipment accurately obtains usable control information. In embodiment, presented as a non-exhaustive example, the digital audio processing may include volume or level, audio frequency equalization, or the amount of an effect applied to the signal. In another non exhaustive example, it may be echo effects applied to the digital audio signal. As is known in the art, the echo effects may be adjusted while the musician plays, for example, the feedback on the echo, which determines the number of audible echo responses, or the level of the effect as compared to the input signal. The musician can control these effects by means of the data transmitted from the SMS Monitor (305). In one embodiment non exhaustive example, the instrument air pressure data sensed by the SMS Sensor (301) may be used as an input into the digital audio processor (307) to set the feedback of the echo, while the elevation of the instrument may be used to set the level of the echo effect. In this example, the musician may perform a melodic motif, but move the instrument to a position where as the motif reaches a crescendo, the amount of echo effect is increased. The output of the audio processor (307) is delivered to a public address or “PA” system (308) in order that the audience hear it. The audio processor (307) may be a component of a larger sound mixing console or an external device connected to a sound mixing console, or a digital audio workstation whose output drives the PA (308), or even delivers audio data to a recording medium for purposes of creating a constituent track of a sound recording.


Given the many possibilities of what digital audio effects are used and which of the sensor data parameters drive which audio effect inputs, the SMS Monitor can route the sensor data by packetizing the data so that a given sensor data output is associated with one or more downstream audio effect parameters. That is, the SMS Monitor (305) may generate a data file (314) stored on a disk comprising the external computer (304) representing predetermined routing matrix, that associates a given sensor data stream with (301) a downstream by way of a network connection (306) audio processing parameter (307). To accomplish this, the external computer (304) may include a routing module that presents to the user a GUI that shows the available sensor data streams and the available downstream audio processing parameter inputs (307). The routing module can then receive from the user input selections that are used to determine or map which sensor data streams go to which downstream audio processing parameters. This routing or mapping matrix may be a data file that can be stored on the computer (314) and recalled by the user. The SMS Monitor (305) then parses the normalized data stream and prepares it for downstream use by the selected audio processing equipment or stage effect controllers.


In a similar manner, the sensor data may be routed to non-audio effects. For example, in an other embodiment, a musician performing on a stage may have stage lights of multiple or variable colors (313). In this embodiment, the SMS Monitor mapping function (314) may map a particular sensor to an electronic device or system that controls the color of the stage lighting (310). As a non-exhaustive example, there may be three lights on the stage, red, green and blue. (313) Each of the lights are powered through a corresponding variable power supply (312), whose outputs determines the amount of light from corresponding light. The three power supplies (312) preferably connected to a typical alternating current power source (311), may be controlled by a light controller module (310) that receives digital data (309) from the SMS Monitor (305) and then adjusts the power supplies in accordance with the digital data stream. Using this system, the musician may set the lighting to be blue, when the instrument is pointed stage left, all three (and therefore white) in the middle, and red when the instrument is pointed stage right. As the sensor data is received by SMS Monitor (305), the routing or mapping module (315) can send the positional data to the lighting controller module (310), which then adjusts the intensity of each light based on the input data stream.


As an alternative embodiment, the process that reads the sensors operating on the SMS Sensor module (301) may be interrupt driven rather than polled. In either case, the air pressure values, orientation values and elevation values are periodically read from the sensor devices. As a result of the foregoing processes, the external computer running the SMS Monitor, (304, 305) obtains data in near real time encoding (i) the air pressure of the musician's mouth region, (i) the orientation of the instrument in the horizontal plane and (iii) elevation of the instrument in a vertical plane perpendicular to the horizontal plane. The external computer running the SMS Monitor (305) takes the received data arriving from the transceiver (316) and pre-processes it. Button pushing at the SMS Remote (302) can cause interruption, causing the system to check which mapping matrix (314) is being used by the routing module (315) or whether the musician is selecting a calibration of the sensors and SMS Monitor to occur as described above. In another embodiment, each sensor can be polled at an independent adjustable frequency. In yet another embodiment, the sensor data may be transmitted from the sensor module in the form of Euler angles, quaternions, raw acceleration, linear acceleration, gravity, or temperature.


In one embodiment, there is a SMS Remote module, (302) which is a device that is attached to the instrument that is operatively connected to the external computer (304) running the SMS Monitor module (305) by means of either the SMS Sensor module (301) or the SMS Monitor directly through its wireless transceiver (316), either case preferably via a wireless communication protocol. A wire may be used to connect the SMS Remote module unit to the SMS Sensor module unit or they may be connected wirelessly. The SMS Remote unit (301) may have one or more electric switches on it that may be actuated by the musician. In one embodiment, a button press is relayed to the sensor unit (301) and then the external computer (304) running the SMS Monitor module (305). In this embodiment, the button press informs the SMS Monitor process (305) that the musician is selecting a calibration mode for the system. In one embodiment, there is one button, and the musician cycles through a series of calibrations, pressing the button each time. For example, positioning for the nominal orientation and minimum elevation, then pressing the button, then positioning for maximum elevation, pressing the button, then maximum left, and pressing the button, and then maximum right and pressing the button. This may be followed by not blowing into the instrument and pressing the button in order to calibrate the ambient air pressure for further data processing as described above. In other embodiments, there may be two buttons, one for orientation, one for air pressure calibration, or three buttons for each of the three sensors. In addition, the buttons may be programmed to turn the entire system on and off. Or, with two buttons, one may turn on and off the use of the sensor data as it applies to the downstream audio processing and the other to turn on and off use of the sensor data as it applies to the performance environment controls.


In one embodiment, the button controllers in the remote device (302) may be used to transmit control data to the SMS Monitor (305) that permits the musician, while on stage and performing, to select which mapping or routing matrix to be used (314). In this embodiment, the button selection on the SMS Remote (302) is detected and transmitted to the SMS Monitor (305). The SMS Monitor (305) can then select which mapping function (314) to use based on the selection from the button. In one embodiment, there may be two mapping functions, and the two buttons select between the two. In another, a single button press can cause the SMS Monitor (305) to cycle to the next matrix mapping, to a last mapping before cycling to a predetermined first mapping matrix. This may be used when the performer prepares to perform the next piece in the repertoire.


In another embodiment, the buttons on the SMS Remote (302) or buttons on the SMS Sensor (301) can be used to select the following functions:


Go to default state. (this is used if there is a panic situation where the entire system is in an error state during a performance, as determined by the musician.)


Initiate Calibration.


System Off.


System On.


The microcontroller in the SMS Sensor (301) is comprised of CPU, main memory, read-only memory and a radio frequency data transceiver, for example Bluetooth™. The read only computer memory is comprised of data that when used as program instructions operating on the CPU, makes the microcontroller operate a process, which includes reading data from the sensor devices and storing that data in the computer memory or writing the sensor data into the data transceiver for transmission to the external computer. The micro-controller also is comprised of a data transceiver unit. This device is addressable by the CPU, both to read data from it and to write data into the device. The communications unit is further comprised of a radio transmitter and receiver. In the preferred embodiment, the radio frequency communication may comply with the Bluetooth™ standard. Similarly, at the process control level, the communications unit can operate a protocol that permits the micro-controller to communicate with external devices, including an external computer, for example, a personal computer. Similarly, the CPU can read the state of buttons on the SMS remote by means of reading data from the transceiver. The SMS Remote is connected to the SMS Sensor by having its own radio frequency data transceiver. By means of inter-process communication, the SMS Monitor can control the behavior of the SMS Sensor unit, and at the same time, the SMS Sensor unit can control the SMS Monitor, while providing it the sensor data stream. The SMS Remote (302) can control the SMS Monitor by having its button data, transmitted to the SMS Sensor and then further transmitted to the SMS Monitor, or, having a direct communication between the SMS Remote and the SMS Monitor utilizing the Bluetooth™ network.


The external computer (304) may be a standard available personal computer, comprised of a central processing unit, main memory, a mass data storage device like a disk drive or solid state drive, a radio frequency data transceiver, like a Bluetooth™ component that provides data to the CPU or transmits data to other devices, a display screen and an input device, either a keyboard, mouse or touch screen input device. The external computer may be comprised of main memory containing program code that when executed by the CPU performs processes described above. The main memory can store the mapping matrices when in use. They may be stored on the mass storage device and then loaded into main memory. They may be generated or edited while in main memory, and the revised versions stored on the mass data storage device. The digital audio processing may occur on the same external computer or on another computer that receives data over a network from the external computer. The lighting and other stage effect controllers (310) may be processes operating on the external computer or on another computer that receives data over a network from the external computer.


In one embodiment, all of the sensors are embodied in one case mounted on the instrument. In addition, the controlling buttons are mounted on a case on the instrument as well. In another embodiment, the connection of data communication between the modules is accomplished using Bluetooth LE™. In one embodiment, the sensor servicing software code operating on the device is interrupt driven. In some cases the pressure sensor is polled while the remaining sensors are interrupt driven. The orientation of the device may be sensed by using a magnetometer. Further, the system is adapted to detect a sequence of movements that permit the musician, while playing to control the system using gesture recognition. Each sensor in the SMS Sensor case may have its own individual data stream to the SMS Monitor. Each may have its own update rate. If the rate of data on the monitor side is greater than its need in the firmware recalculation, then preprocessing may be applied to interpolate and thereby generate interpolated data points for the downstream controllers.


The pre-processing features are meant to be a part of what currently takes place in the monitor. After the data has been received and parsed, it can be calibrated along provided min/max and offset values; scaled within the −1 to 1 range; filtered against noise or unwanted incidences; and tested against recorded gesture primitives. Thus, the monitor applications remains an optional monitoring tool and reduces on the personal computer both the CPU needs and display space, that can be assigned to other tasks.


The latency control accesses at least two parameters: the Bluetooth connection interval that is controlled at receiver (master) side and a priority control to ensure that the data stream is not delayed by some higher priority task. In addition, it is easier to rely on a given Bluetooth version (currently 4.2, eventually upgrading to 5.0), with its own hardware rather than depending on computer age and operating systems (for example, Apple works with Bluetooth 4.0 to 4.2, pre-2011 computers are not Low Energy compatible).


The data stream follows the following sequence:

    • 1. If new data exists, it is acquired at the next connection anchor (which determines the connection interval and can be optimized);
    • 2. data is parsed depending on its origin (which sensor, but also which device if several are connected)
    • 3. parsed data is pre processed—if needed—that is, it is calibrated, scaled and filtered
    • 4. pre-processed data is formatted and sent via either an UDP or an USB connection to a computer
    • 5. formatted data can be monitored on the computer or used as-is with any software application that takes the formatted data as input for controlling its operation.

Claims
  • 1. A system for controlling in real-time a stage effect equipment comprising: A sensor module comprised of at least one sensor that detects a corresponding at least one physical condition of a musical instrument while it is being played, such physical conditions including: mouth pressure and instrument position, said sensor module configured to convert the at least one sensor detections into a substantially real-time corresponding at least one data stream, and further comprised of a transmitting data transceiver that transmits the at least one data streams to a monitor module;the monitor module comprised of a receiving data transceiver configured to receive the transmitted at least one data streams, said monitor module further configured to map the at least one incoming data stream to an at least one corresponding output data stream, in reliance on a data file stored in a computer memory comprising the monitor module, said computer memory comprised of data representing a mapping of the at least one incoming data stream, and further configured to reformat the at least one incoming data stream into a format compatible with a downstream device controller determined from the mapping, and further normalize and offset each at least one data streams to a corresponding at least one predetermined maximum and minimum data value pairs associated with the determined downstream device controller;said monitor module configured to transmit the reformatted at least one data streams to an at least one corresponding device controllers;said device controllers configured to receive the formatted data stream and modify the operation of the stage effect equipment substantially in real time using the at least one data streams.
  • 2. The system of claim 1 where the stage effect equipment is comprised of a light, and the device controller is a light brightness controller.
  • 3. The system of claim 1 where the stage effect equipment is an audio signal processor that applies a predetermined effect to the audio signal passing through it and the device controller is a parameter control of the audio signal processor effect.
  • 4. The system of claim 1 further configured to receive a first and a second position data and use the received position data to determine the at least one predetermined maximum and minimum data pairs.
  • 5. The system of claim 1 further configured to receive a first and a second air pressure data and use the received air pressure data to determine the at least one predetermined maximum and minimum data pairs.
  • 6. The system of claim 1 further configured to scale the formatted data stream into the range −1 to 1.
  • 7. The system of claim 1 further configured to filter against noise in the data stream.
  • 8. The system of claim 1 where the transmitted at least one data stream encodes an at least one data representing a corresponding at least one gesture feature.
  • 9. The system of claim 1 further comprised of a computer comprising a display device, said display device configured to display the apparent position of the instrument in real time as a three dimensional graphic.
  • 10. The system of claim 9 where the three dimensional graphic is in the form of a joystick diagram.
  • 11. The system of claim 9 where the three dimensional graphic is in the form of an airplane diagram.
  • 12. The system of claim 1 where the data stream is comprised of data packets, each data packet comprised of data representing which sensor the data packet is associated with and further configured to parse the data packets to obtain the data representing the sensor association in order to use the obtained data to determine the routing of the data stream to the corresponding device controller.
  • 13. The system of claim 1 where the at least one sensor comprising the sensor module occupy a physical package mounted on the instrument.
  • 14. The system of claim 1 where the position of the instrument is detected using a magnetometer as a sensor.
  • 15. The system of claim 1 further configured to generate data for the data stream from the at least one sensor by means of an interrupt driven process.
  • 16. The system of claim 1 further configured to generate data for the data stream from the at least one sensor by means of a polling driven process.
  • 17. The system of claim 16 where there is at least two different polling rates for two different sensors.
  • 18. The system of claim 1 further configured to generate additional data for the formatted data stream output by interpolating the incoming sensor data.
  • 19. The system of claim 1 further configured to have an operational logic state and a calibration logic state, and is further configured to set the predetermined maximum and minimum data values when the system is in the calibration state and further configured, when in the operational logic state, to scale data comprising the data stream using the set predetermined maximum and minimum data values.
  • 20. The system of claim 19 where the selection of the two logic states is determined using switch controllers on the sensor module.
  • 21. The system of claim 1 where one of the sensors comprising the sensor module is a pressure sensor that detects pressure in the range of 10-1300 millibars.
  • 22. The system of claim 1 where the system is further configured to scale the data comprising the data stream by using a function that is one of: log of the data, exponent of the data.
  • 23. The system of claim 1 where the data streams for different sensors are given different priorities so that sensors mapped to audio processors have higher priority than sensors mapped to lighting controllers.
  • 24. The system of claim 1 where the at least one sensor are comprised of at least one of: accelerometer, air pressure, magnetometer, gyroscope.
  • 25. The system of claim 1 further configured to receive a control signal from the sensor module that instructs the monitor to change a first predetermined mapping of the data streams to a second predetermined mapping.
  • 26. The system of claim 1 further configured to have a panic logic state and to switch to that state upon receiving a command from the module.
  • 27. The system of claim 26 where the panic logic state transmits a predetermined default control data to the downstream controller.
PRIORITY

This application is a non-provisional continuation of U.S. Pat. App. No. 62/576,944 filed on Oct. 25, 2017, which is hereby incorporated by reference in its entirety for all that it teaches.

US Referenced Citations (21)
Number Name Date Kind
5286913 Higashi Feb 1994 A
5525142 Yamauchi Jun 1996 A
6538189 Ethington Mar 2003 B1
6689947 Ludwig Feb 2004 B2
7309829 Ludwig Dec 2007 B1
20020005108 Ludwig Jan 2002 A1
20020005111 Ludwig Jan 2002 A1
20040069129 Ludwig Apr 2004 A1
20050120870 Ludwig Jun 2005 A1
20050217464 Onozawa Oct 2005 A1
20070017352 Masuda Jan 2007 A1
20070144336 Fujii Jun 2007 A1
20070261540 Gremo Nov 2007 A1
20080017014 Suzuki Jan 2008 A1
20090020000 Onozawa Jan 2009 A1
20140251116 Peterson Sep 2014 A1
20150101477 Park Apr 2015 A1
20180137846 Pouillard May 2018 A1
20180268791 Okuda Sep 2018 A1
20190019485 Toyama Jan 2019 A1
20190122644 Mueller Apr 2019 A1
Foreign Referenced Citations (1)
Number Date Country
WO-2012098278 Jul 2012 WO
Non-Patent Literature Citations (2)
Entry
S. Schiesser and J. C. Schacher, “SABRe: The Aug-mented Bass Clarinet,” in Proceedings of the 12th International Conference on New Interfaces for Mu-sical Expression International Conference on New Interfaces for Musical Expression. University of Michigan, May 2012.
Sebastien Schiesser, Jan C. Schacher. SABRe: Affordances, Realizations and Perspectives. Institute for Computer Music and Sound Technology, Zurich, Switzerland. Sep. 25, 2015.
Related Publications (1)
Number Date Country
20190122644 A1 Apr 2019 US
Provisional Applications (1)
Number Date Country
62576944 Oct 2017 US