Tuning a stringed musical instrument includes the act of making minute adjustments to the tensions of the strings to properly align the intervals between their tones so that the instrument is in tune. Many factors can cause these instruments to go out of tune over time, particularly atmospheric changes. For instance, changes in humidity can affect the pitch of an instrument. An out-of-tune instrument can often be identified by the characteristic beating sound it produces. This fluctuation in the sound intensity may be a result of two or more tones, containing similar frequencies, played together. Fine tuning includes an assessment of the vibration interaction among notes, which may be different for every instrument, and thus in practice involves matching the notes to slightly different pitches from any theoretical standard.
The present disclosure is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings.
Embodiments are described for an electronic measuring device. One application of the device is for tuning of musical instruments, such as a piano, harpsichord, or other string instrument. A vibrating string produces vibrations at a number of frequencies above the fundamental pitch of the corresponding note. These vibrations may be referred to as overtones, or as harmonics when the overtones are at integer multiples (e.g., 2×, 3× . . . 6× . . . ) of the fundamental frequency. When multiple notes are played together, or at least when multiple strings of the instrument are vibrating simultaneously, an interference among the harmonic frequencies of the multiple notes may cause a beating effect (i.e., a disturbing perceived fluctuation in the sound intensity). The beating occurs when the harmonic frequencies of multiple notes are close to one another, but slightly different.
In one embodiment, the electronic measuring device described herein assists in the tuning of the music instrument by calculating the difference between the harmonic frequencies of each string and providing feedback based on those calculations. The electronic measuring device (also referred to herein as a “tuning device”) utilizes a mathematical model that describes the beating of arbitrarily combined strings after each string's individual properties are recorded. In one embodiment, operation of the tuning device is divided in to two stages. The first stage includes a recording of the instrument's initial acoustic properties. During this stage, the tuning device captures and records a waveform for each individual string of the instrument. All information used by the device is based on the acoustic waveforms generated by the musical instrument, which may be captured with a microphone or other acoustic signal capture device. The second stage includes a tuning procedure, during which each string is tuned individually. During both stages multiple frequency components of each note are taken into account.
In one embodiment, tuning device 120 is a dedicated hardware device, based on micro-controller technology, and is fully functional by itself for standalone application. In this embodiment, no additional hardware such as a computer or other hand-held device is needed. In another embodiment, the functionality of tuning device 120 described herein may be implemented on some other general-purpose device, such as a desktop personal computer (PC), server, workstation, laptop, handheld computer, personal digital assistant (PDAs), smart phone, and so forth.
In either embodiment, tuning device 120 includes a microphone 122, a display device 124, a processing device 126 and a data store 128. In one embodiment, microphone 122 may be configured to capture a plurality of audio samples, including for example, the sounds 112 produced by the vibrating strings of instrument 110. Microphone 122 may include a transducer that converts the sounds 112 into an electrical signal which can be further processed by tuning device 120. For example, microphone 122 may use electromagnetic induction, capacitance change, piezoelectricity, or some other technology to produce the electrical signal from air pressure variations associated with the sounds 112.
Display device 124 may be configured to present a visual output of tuning device 120 for view by a user. In one embodiment, display device 124 may include a liquid crystal display (LCD) device or a cathode ray tube (CRT) display device. In one embodiment, display device 124 may include a stroboscopic display designed to display the sonic level and the calculated beating of the harmonic frequencies on a bar-graph display. The display may present a visual phenomenon known as the “stroboscopic effect” caused by aliasing that occurs when continuous motion is represented by a series of short or instantaneous samples. This effect occurs when the view of a moving bar graph is represented by a series of short samples as distinct from a continuous view, and the moving bar graph is in cyclic motion at a rate close to the sampling rate.
In one embodiment, tuning device 120 includes one or more processing devices 126, each comprising one or more processor cores. Each processor core includes circuitry for executing instructions according to a predefined general-purpose instruction set. For example, the x86 instruction set architecture may be selected. Alternatively, the ARM®, Alpha®, PowerPC®, SPARC®, or any other general-purpose instruction set architecture may be selected. The processor cores may access cache memory subsystems for data and computer program instructions. The cache subsystems may be coupled to a memory hierarchy comprising random access memory (RAM) and a storage device. In one embodiment, data store 128 may include one or more mass storage devices which can include, for example, flash memory, magnetic or optical disks, or tape drives; read-only memory (ROM); random-access memory (RAM); erasable programmable memory (e.g., EPROM and EEPROM); flash memory; or any other type of storage medium.
In one embodiment, processing device 126 executes tuning module 130 to perform the various operations described herein. For example, tuning module 130 may instruct microphone 122 to capture a plurality of audio samples of sound 112 and store those audio samples in data store 128. Tuning module 130 may further identify a plurality of frequency components (including the fundamental frequency and one or more harmonic frequencies) of each of the plurality of audio samples and then calculate an optimal tuning curve based on those frequency components. The optimal tuning curve may define certain tuning parameters (e.g. frequencies) designed to reduce an audible beating effect when two or more strings of instrument 110 are excited simultaneously. The optimal tuning curve may seek to define frequencies where the harmonic frequency components corresponding to different strings of instrument 110 overlap in order to reduce or eliminate the beating effect. Tuning module may further determine a deviation of the frequency components for a given string from the optimal tuning curve and may cause display of an indication of this deviation on display device 124. A user of tuning device 120 can view the displayed indication and utilize that feedback to perform a tuning adjustment on instrument 110, such as adjusting the tension of a particular string. Additional details of the operation of tuning module 130 are provided below with respect to
Referring to
At block 220, method 200 stores the plurality of audio samples in data store 128. In one embodiment, upon capturing each audio sample at block 210, tuning module 130 stores the audio sample in data store 128. In one embodiment, tuning module 130 may add each audio sample to an entry corresponding to a particular key/string of instrument 110. In one embodiment, the audio sample data may be stored as part of a profile data associated with the particular instrument 110. This profile data may be saved indefinitely in data store 128 so that historical data can be accessed in the future. Depending on the embodiment, various data structures can be used to implement the data store 128, such as for example, a circular data buffer, ring buffer or other first-in, first-out structure.
At block 230, method 200 applies a windowing function to the plurality of audio samples captured at block 210. In one embodiment, tuning module 130 accesses data store 128 and copies at least a portion of the buffer into a window for spectral analysis using, for example, the Fast Fourier Transform algorithm.
Depending on the effective frequency content of the note being tuned a different temporal window size may be utilized to reach a constant accuracy of the tuning device 120. In one embodiment, this is realized with a window size covering a constant number of oscillations for the lowest present frequency. A response constant nosc representing the number of oscillations of the device can be adjusted to the environmental needs. For low noise environments, a smaller response constant can be chosen to ensure a fast response. In situations with high background noise, however, a higher response constant can be chosen to effectively suppress uncorrelated short-time background noise.
In one embodiment, the routine is optimized to achieve a minimum sine wave measuring accuracy of ±0.05 Ct over a frequency range f within fmin to fmax [Hz] with a response window of 10 to 150 number of oscillations nosc. The value of fmin may be limited by the recording duration while fmax is limited by the sampling rate of the device. Prior to display of the result the response time is t=nosc/flow [seconds]. In one embodiment, flow is the lowest present frequency for the active note.
Truncation of the audio data to this response time can influence the spectral analysis significantly. An uncontrolled transition from the end of the window to the beginning can lead to a jump due to the periodicity introduced by the Fast Fourier Transform algorithm. This effect is illustrated in
Referring again to
The deviation can be described as:
Measurements showed that reducing the inharmonicity to the second order effect inharm=inharm2 and, therefore, a deviation of Dev=inharm·f2 may be suitable for most situations. The unit of inharm then is defined to be Ct/Hz2. Based on this model the frequencies fn can be described as shown below:
fn=fni·facCtDev(n≥1,n∈IN)
fni=n·f1i(n≥1,n∈IN)
Dev=inharm·fni2
All frequency components of a single string may be described by their harmonic order n≥1, n∈IN, the idealized fundamental frequency f1i, and the inharmonicity inharm as shown above.
Calculating the value of inharm from a pair of two measured fn describes an equation system. This system is solved and used by the algorithm to retrieve the inharmonicity and f1i from the measured frequency components. The value n needs to be retrieved for each fn from the low frequency content and might be simplified by a user-specified note value. The value inharmeff which is used by the device to calculate the ideal tuning curve is an effective value retrieved from at least one pair of strong harmonics monitored over time. The spectral energy envelope shape is accounted for by the position of the spectral mean of the individual spectral components. The model includes several frequency components for each note.
Most instruments with 12 intervals per octave can be tuned by this device. Based on the harmonic content of each note, the main four intervals are optimized in terms of beating. The main intervals without the effect of inharmonicity are shown in Table 1. With a step of 100 Ct per interval the octave is a step of 1200 Ct which corresponds to a factor of 2.
Due to inharmonicity, the natural intervals are larger than the values given in Table 1. Taking this effect into account when tuning the instrument is often described as stretched tuning. As a next step, the tuning curve is optimized by minimizing the low frequency beating of the main four intervals. An example for a possible measurement of a piano A4 string with fn, the retrieved idealized fundamental frequency f1i and effective inharmonicity inharmeff is shown in Table 2.
Referring again to
Referring again to
Referring again to
At block 280, method 200 captures an updated audio sample corresponding to a first string of musical instrument 110 after a tuning adjustment is performed on the first string. In response to viewing the display information presented at block 270, the user may take some action to make a tuning adjustment on instrument 110. For example, the user may adjust the tension of the string using techniques well known to those of skill in the art. After making the tuning adjustment, the user may again excite the first string, and microphone 122 may capture an updated audio sample. In one embodiment, tuning module 130 may store this updated audio sample in data store 128. The constant monitoring of the instrument's data ensures adaptation of the tuning curve to changing properties of the instrument due to environmental changes or other influences, such as pitch change.
At block 290, method 200 determines an updated deviation of a plurality of frequency components of the updated audio sample from the optimal tuning curve. In one embodiment, tuning module 130 compares the updated positions of the harmonic frequencies after tuning to the ideal positions defined in the optimal tuning curve. If further deviation remains, method 200 may return to block 270 and present additional feedback to the user. These operations may be repeated until the deviation for the current string is eliminated or minimized below some defined threshold. In addition, these operations may be performed for each key/string/note of musical instrument 110 until the deviations of each harmonic frequency from the optimized tuning curve are eliminated or minimized below the threshold.
The exemplary computer system 800 includes a processing device (processor) 802, a main memory 804 (e.g., read-only memory (ROM), flash memory, dynamic random access memory (DRAM) such as synchronous DRAM (SDRAM)), a static memory 806 (e.g., flash memory, static random access memory (SRAM)), and a data storage device 818, which communicate with each other via a bus 830.
Processing device 802 represents one or more general-purpose processing devices such as a microprocessor, central processing unit, or the like. More particularly, the processing device 802 may be a complex instruction set computing (CISC) microprocessor, reduced instruction set computing (RISC) microprocessor, very long instruction word (VLIW) microprocessor, or a processor implementing other instruction sets or processors implementing a combination of instruction sets. The processing device 802 may also be one or more special-purpose processing devices such as an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), a digital signal processor (DSP), network processor, or the like. The processing device 802 is configured to execute tuning module 130 to perform the adaptive tuning as described herein.
The computer system 800 may further include a network interface device 808. The computer system 800 also may include a video display unit 810 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)), an alphanumeric input device 812 (e.g., a keyboard), a cursor control device 814 (e.g., a mouse), and a signal generation device 816 (e.g., a speaker).
The data storage device 818 may include a computer-readable medium 828 on which is stored one or more sets of instructions 822 (e.g., instructions of tuning module 130) embodying any one or more of the methodologies or functions described herein. The instructions 822 may also reside, completely or at least partially, within the main memory 804 and/or within processing logic 826 of the processing device 802 during execution thereof by the computer system 800, the main memory 804 and the processing device 802 also constituting computer-readable media. The instructions may further be transmitted or received over a network 820 via the network interface device 808.
While the computer-readable storage medium 828 is shown in an exemplary embodiment to be a single medium, the term “computer-readable storage medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions. The term “computer-readable storage medium” shall also be taken to include any medium that is capable of storing, encoding or carrying a set of instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of the present invention. The term “computer-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories, optical media, and magnetic media.
The preceding description sets forth numerous specific details such as examples of specific systems, components, methods, and so forth, in order to provide a good understanding of several embodiments of the present disclosure. It will be apparent to one skilled in the art, however, that at least some embodiments of the present disclosure may be practiced without these specific details. In other instances, well-known components or methods are not described in detail or are presented in simple block diagram format in order to avoid unnecessarily obscuring the present disclosure. Thus, the specific details set forth are merely exemplary. Particular embodiments may vary from these exemplary details and still be contemplated to be within the scope of the present disclosure.
In situations in which the systems discussed herein collect personal information about users, or may make use of personal information, the users may be provided with an opportunity to control whether programs or features collect user information (e.g., information about a user's social network, social actions or activities, profession, a user's preferences, or a user's current location), or to control whether and/or how to receive content from the media server that may be more relevant to the user. In addition, certain data may be treated in one or more ways before it is stored or used, so that personally identifiable information is removed. For example, a user's identity may be treated so that no personally identifiable information can be determined for the user, or a user's geographic location may be generalized where location information is obtained (such as to a city, ZIP code, or state level), so that a particular location of a user cannot be determined. Thus, the user may have control over how information is collected about the user and used by the web server or media server.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiments included in at least one embodiment. Thus, the appearances of the phrase “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. In addition, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.”
Although the operations of the methods herein are shown and described in a particular order, the order of the operations of each method may be altered so that certain operations may be performed in an inverse order or so that certain operation may be performed, at least in part, concurrently with other operations. In another embodiment, instructions or sub-operations of distinct operations may be in an intermittent and/or alternating manner.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2016/051995 | 9/15/2016 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2017/048998 | 3/23/2017 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
4498363 | Shimada | Feb 1985 | A |
4803908 | Skinn et al. | Feb 1989 | A |
5773737 | Reyburn | Jun 1998 | A |
5824929 | Freeland et al. | Oct 1998 | A |
5977467 | Freeland et al. | Nov 1999 | A |
6084167 | Akimoto et al. | Jul 2000 | A |
6448487 | Smith | Sep 2002 | B1 |
6529843 | Carpenter | Mar 2003 | B1 |
6995311 | Stevenson | Feb 2006 | B2 |
7064261 | Shao | Jun 2006 | B2 |
7268286 | Carpenter | Sep 2007 | B2 |
7521618 | Okuyama | Apr 2009 | B2 |
7928306 | Lemons | Apr 2011 | B2 |
8022284 | Velez Medicis | Sep 2011 | B1 |
8373053 | Nielsen | Feb 2013 | B2 |
9076416 | Nielsen | Jul 2015 | B2 |
20060288850 | Okuyama | Dec 2006 | A1 |
20070079688 | Okuyama et al. | Apr 2007 | A1 |
20070084330 | Okuyama | Apr 2007 | A1 |
20080270904 | Lemons et al. | Oct 2008 | A1 |
20130145921 | Ribner | Jun 2013 | A1 |
20140060289 | Hirshberg | Mar 2014 | A1 |
20180277083 | Ruchert | Sep 2018 | A1 |
Number | Date | Country |
---|---|---|
101793873 | Jan 2013 | CN |
Entry |
---|
Dirk's Piano Tuner v4.0, viewed at https://www.dirksprojects.nl/index.php?Lan=english&Page=Tuner/piano_tuner_40.php 2010. |
International Search Report and Written Opinion for PCT Application No. PCT/US2016/051995, dated Nov. 29, 2016, 7 pages. |
Bachmann et al., “Prisma—A Timbre Tuning Device for Musicians and Instrument Makers”, http://www.prisma-music.ch/downloads/isma2007prismapaper.pdf, ISMA 2007, 8 pages. |
Kageyama, Noa, “Five Best Tuner Apps—The Bulletproof Musician”, http://www.bulletproofmusician.com/five-best-tuner-apps/, retreived on Mar. 19, 2019, 12 pages. |
Hartquist, John, “Real-Time Musical Analysis of Polyphonic Guitar Audio”, http://digitalcommons.calpoly.edu/cgi/viewcontent.cgi?article=1853&context=these, Jun. 2012, 55 pages. |
European Extended Search Report for EP Application No. EP16847333, dated Apr. 3, 2019, 7 pages. |
Number | Date | Country | |
---|---|---|---|
20180277083 A1 | Sep 2018 | US |
Number | Date | Country | |
---|---|---|---|
62220657 | Sep 2015 | US |