The field of the invention is digital music communication devices.
Digital music devices have tong been used to play digital music from a digital music source to a speaker. For example, a CD player can read music encoded in digital format on a CD and then play that music on the speaker connected to the CD player. In the 1980's, the MIDI standard was developed, which allows a digital instrument to send digital event data to a synthesizer, which then produces sounds that correspond to the digital event data. US20070276978 to Wang, for example, teaches a receiver that is connected to a computer using a USB (Universal Serial Bus) port, allowing the computer to send MIDI event data to the digital music receiver which either stores the event data in a storage unit or produces sounds via an audio device. Wang's digital music controller, however, will only map the computer's signal to a single audio output device. Wang and all other extrinsic materials discussed herein are incorporated by reference in their entirety. Where a definition or use of a term in an incorporated reference is inconsistent or contrary to the definition of that term provided herein, the definition of that term provided herein applies and the definition of that term in the reference does not apply. Unless the context dictates the contrary, all ranges set forth herein should be interpreted as being inclusive of their endpoints, and open-ended ranges should be interpreted to include commercially practical values. Similarly, all lists of values should be considered as inclusive of intermediate values unless the context indicates the contrary.
U.S. Pat. No. 6,342,666 to Shutoh, teaches an interface unit with several MIDI inputs and MIDI outputs that could be mapped to one another using a computer coupled to the interface unit. Shutoh's interface unit, however, requires a computer to be coupled to it at all times in order to transfer data from a MIDI input and a MIDI output and the computer then produces more MIDI event data to be sent to corresponding MIDI outputs.
It has yet to be appreciated that MIDI interface units could be produced that do not need a computer coupled to the interface unit to translate event data from a MIDI input to a MIDI output.
Thus, there is still a need for improved MI interface units.
The inventive subject matter provides apparatus, systems and methods in which a digital music router hostlessly transmits digital music event data from one port to another. As used herein, a “hostless” device is a device that is not coupled to a computer system. As used herein, and unless the context dictates otherwise, the term “coupled to” is intended to include both direct coupling (in which two elements that are coupled to each other contact each other) and indirect coupling (in which at least one additional element is located between the two elements). Therefore, the terms “coupled to” and “coupled with” are used synonymously.
Generally, the digital music router has a plurality of ports of different kinds, such as MIDI DIN ports (preferably MIDI DIN IN/OUT pairs of ports), USB ports, serial ports, or TRS connectors. In an exemplary embodiment, the digital music router has a plurality of MIDI DIN ports for coupling to MIDI devices and a plurality of USB ports for connecting to a host or a USB hub or USB-MIDI instruments. While the digital music router can transmit digital event data from any port to any other port via a configuration user interface, preferably the digital music router has a default routing configuration that allows a user to immediately use the router without any pre-configuration, allowing for immediate hostless routing multiple MIDI transmitters with multiple MIDI receivers. As used herein, a transmitter is any device that transmits information or data, such as a keyboard, drum pad, host computer system, or electric guitar, and a receiver is any device that receives information or data, such as a synthesizer, a host computer system, or a storage and playback device (a sequencer), which can store and play back events to the originating MIDI device or to other MIDI devices.
Transmitters and receivers could be coupled to the router in a variety of ways. For example, each transmitter and each receiver could be plugged into a separate port on the router. Alternatively, a port could be coupled to a port hub that virtually splits a single port into multiple virtual ports, which are each then individually addressable by the router. Such addressing/enumerating is preferably automatic in the case of generic hubs, for example a 4-port USB hub or a 2-port serial port splitter. In an alternative embodiment, multiple transmitters or receivers could be daisy-chained with one another, and each transmitter and/or receiver is logically addressable by the router. Since music event data generally can not be merely routed from an input port to an output port, the router transmits data by first receiving music event data from a transmitter coupled to a designated input port, reproduces that music event data, and then transmits that reproduced music event data to a designated output port. Once the transmitters and receivers are coupled to the router and addressed by the router system, one could preferably access a user interface that assists a user in determining how music event data is routed from one port to another.
The user interface for the router could be accessed via a touch screen or keypad on the router, but is preferably accessed by a host coupled to the router. A host could be coupled to the router using a physical wire coupling or wirelessly, such as by using a Wi-Fi or Bluetooth connection, and can generally dictate a routing profile that will determine how music event data is handled by the router. Preferably, when a host computer system is coupled to a port on the router, the router can automatically detect that a host computer system is coupled to that port and not a simple MIDI transmitter/receiver.
A routing profile dictated by the user interface could comprise a plurality of instructions for routing music event data, for example by routing music event data from a designated input port to a designated output port, by replicating music event data from a designated input port to two or more designated output ports, by merging data from two designated input ports to a designated output port, by filtering out specific music event data received by an input port, by filtering out specific music event data transmitted to an output port, by translating music event data from an input port using one protocol to music event data to an output port using a different protocol, by designating timing and/or delays between receiving music event data and transmitting music event data, or by transmitting data from two designated input polls in a serial stream with one music event from one port following a music event from a second port. Contemplated protocols include MIDI, USB-MIDI, MIDI (MIDI 2.0), and analog data streams. In an exemplary embodiment, the router is capable of routing data from one MIDI protocol version to another MIDI protocol version.
Once a routing profile is created, the user could then unplug the host computer from the router, and use the router to transmit digital event data to and from a plurality of devices coupled to the router without need of a host coupled to the router. Generally, the router has a processor and a memory to handle such administration and traffic management. Preferably, a user could save one or more routing profiles to the router, and could select different routing profiles using a switch or button on the router, or via the user interface by coupling a host to the router.
While a contemplated router could hostlessly route music event data, a preferred router could also route music event data while one or more hosts are coupled to the router, allowing MIDI event data to be transmitted to or from the host for a variety of purposes. For example, by using a virtual keyboard on a host computer system to send MIDI event data to an attached receiver, or by using a host computer system to record all MIDI event data being routed by the router. This is especially useful for functionality that can only be performed on host computers.
In an exemplary embodiment, the router is embedded within a transmitter (such as an electric piano, an electric guitar, or an electric drum pad) or a receiver (such as a synthesizer, a speaker, or a storage device). In such embodiments, the router performs the dual functionality of routing music event data and transmitting or reproducing music event data.
Various objects, features, aspects and advantages of the inventive subject matter will become more apparent from the following detailed description of preferred embodiments, along with the accompanying drawing figures in which like numerals represent like components.
One should appreciate that the disclosed techniques provide many advantageous technical effects including the ability to hose a USB-MIDI device without a host computer coupled to the router, the ability to route MIDI data between a plurality of transmitters and receivers, the ability to route MIDI data between multiple hosts, the ability to route MIDI data between hosts and MIDI instruments, and the ability to route MIDI data between USB-MIDI devices and hosts. As used herein, a “host” system could mean a personal computer system, such as a desktop or a laptop computer, or a handheld computer system, such as a tablet personal computer or a PDA. As used herein, a “handheld” computer host system is a host system that can comfortably be held in a human hand and is typically less than 10 or 5 pounds. For example an iPhone™, iPod™, or an iPad™.
It should be noted that while the embodiments herein disclose personal desktop computers and handheld computers, various alternative configurations are also deemed suitable and may employ various computing devices including servers, interfaces, systems, databases, engines, controllers, or other types of computing devices operating individually or collectively. One should appreciate the computing devices comprise a processor configured to execute software instructions stored on a tangible, non-transitory computer readable storage medium (e.g., hard drive, solid state drive, RAM, flash, ROM, etc.). The software instructions preferably configure the computing device to provide the rotes, responsibilities, or other functionality as discussed below with respect to the disclose apparatus. In especially preferred embodiments, the various servers, systems, databases, or interfaces exchange data using standardized protocols or algorithms, possibly based on HTTP, HTTPS, AES, public-private key exchanges, web service APIs, known financial transaction protocols, or other electronic information exchanging methods. Data exchanges preferably are conducted over a packet-switched network, the Internet, LAN, WAN, VPN, or other type of packet switched network.
In
USB device adapter 120 is an adapter that couples to USB-MIDI transmitters and receivers, raw MIDI adapter 130 is an adapter that couples to MIDI devices, preferably using a serial connector, USB Host adapter 140 is an adapter that could couple either to a host computer system using a USB connector or to other USB-MIDI devices using a USB connector, and proprietary host adapter 150 is an adapter that couples to a host computer system using a proprietary connector with a proprietary operating system (for example a Palm™ Pilot operating system or an iPad™ operating system). Each of the adapters are used herein euphemistically as adapters that couple with devices that are capable of sending data through a port, and preferably each adapter is capable of sending music event data through a port. Other adapters could be coupled with MIDI manager 110 without departing from the scope of the invention to handle other protocols known in the art.
MIDI manager 110 handles the intelligent routing of event data messages between the various ports 121, 131, 141, and 151 on router 100 via adapters 120, 130, 140, and 150, respectively. Since each of the ports could transmit event data messages using a variety of protocols, music event data manager 110 preferably has drivers that can understand and translate event data messages from one protocol to another, or the drivers could be embedded in each driver individually, allowing for music event data manger 1110 to seamlessly communicate between each of the adapters as if each one of the adapters were using the same protocol, for example the MIDI 1.0 protocol or the HD-MIDI protocol. Conversion of event data from one protocol to another could be handled by either software or hardware elements without departing from the scope of the invention.
In this embodiment, messages could be assumed to be valid when they are passed to a port. In order to avoid conflict, however, message filters could be incorporated to constrain the data to exclude inadvertent messages which could cause undesirable operation of either router 100 itself or to devices coupled to the ports. This filtering could be necessary when using instruments that malfunction when invalid messages are received. For example, a filter to prevent vibrato from being sent to a keyboard synthesizer. Filters could be applied to incoming ports or adapters to prevent events from being received by messaging queue 111, or filters could be applied to outgoing ports or adapters to prevent events from being sent to certain MIDI devices. In general, all messages are sent to host devices coupled to router 100, since most hosts can handle any event, even undefined events. However, it is contemplated that filters could be applied to certain hosts that require some error control handling, or to reduce the workload of messaging queue 118.
Preferably, USB connectors 332 and 334 are “smart connectors” which can determine whether a device coupled to the USB connector is a smart host computer system or a dumb MIDI transmitter or receiver. When a host computer is coupled to one of the USB connectors 332 and 334, router 300 will, by default, route all MIDI event data information to that host computer at all times, increasing the amount of information the attached host computer has at its disposal to assist in administration of MIDI music flowing through router 300. Once a user has properly configured router 300 through the host computer, the host computer could be removed from router 300.
An alternative router 400 is shown in
Host handheld computer 520 has an accelerometer that could translate the angle that the host handheld computer 520 is tilted at into MIDI pitch event data which is then sent to router 400. USB hub 590 allows up to four devices to be coupled to its ports, which allows the plurality of devices coupled to USB hub 590 to be realized by a virtual addressing scheme adopted by router 400. USB-MIDI devices could be coupled to USB hub in parallel, such as with drum pad 530 and keyboard 540, or in serial, such as with keyboard 540 and guitar 550. The signals from each of these devices are then merged by router 400 and MIDI event data is then sent to synthesizer 560 to be played on speaker 570, and is sent to storage device 580 to be saved. After host computer 510 configures the appropriate routing for the devices, host computer 510 could be removed from the system without impacting the transmission of MIDI event data from the instruments to synthesizer 560 and storage device 580. In fact, host computer 520 could also be removed, if pitch data is no longer wanted by the users playing the instruments.
It should be apparent to those skilled in the art that many more modifications besides those already described are possible without departing from the inventive concepts herein. The inventive subject matter, therefore, is not to be restricted except in the scope of the appended claims. Moreover, in interpreting both the specification and the claims, all terms should be interpreted in the broadest possible manner consistent with the context. In particular, the terms “comprises” and “comprising” should be interpreted as referring to elements, components, or steps in a non-exclusive manner, indicating that the referenced elements, components, or steps may be present, or utilized, or combined with other elements, components, or steps that are not expressly referenced. Where the specification claims refers to at least one of something selected from the group consisting of A, B, C . . . and N, the text should be interpreted as requiring only one element from the group, not A plus N, or B plus N, etc.
This application claims the benefit of priority to provisional application No. 61/296,504 filed Jan. 20, 2011.
Number | Date | Country | |
---|---|---|---|
61296504 | Jan 2010 | US |