The present invention relates to a single-transducer full duplex talking circuit.
In recent years, progress has been made in the microminiaturization of full duplex talking devices such as wireless hands-free earphone microphones, for example, and effects such as feedback or echo tend to be more likely to occur due to the reduction of the physical distance between the speakers and microphones used in earphone microphones. In addition, since it is essential that an earphone be placed in close proximity to the ear, it has become necessary to increase microphone sensitivity due to the increased distance between the microphone and the mouth producing the sound. This results in a situation in which it is extremely difficult to hear due to the effects of external noise or wind noise caused by high winds. In order to solve these problems, devices such as ultra-miniature hands-free earphone microphones incorporating echo prevention circuits or noise reduction circuits have been developed.
However, in a full duplex talking device in which the earphone and microphone are independent, in particular, since the microphone which generates transmission signals is placed in open space with constantly changing ambient acoustic characteristics, there are limits to the extent that factors inhibiting this communication can be predicted and reduced on a practical level. Even if circuits or algorithms necessary for echo prevention or noise reduction circuits are used, the scope of practical use is restricted by the effects of substantial external noise or wind noise due to strong wind.
Therefore, single-transducer type talking devices, which eliminate the effects of external noise by integrating the microphone inside the earphone, have been developed. For example, a full duplex talking circuit includes, a digital signal processing circuit is combined with an analog bridge circuit containing a single transducer to realize an echo canceling function which removes reception signals mixed with the transmission signals of the single transducer across almost all voice frequency bands.
However, various characteristics, including the strength of a transmission signal, generally change from moment to moment, and the transmission signal that is input into the single transducer is an audio signal that has passed through various organs of the body, including the eardrum. Therefore, it is necessary to compensate for the fact that the frequency characteristics have dramatically diminished due to the acoustic transfer characteristics of the human body.
In an actual situation in which the ambient acoustic environment changes in this way, not only does the echo canceling function fail to operate adequately in a conventional full duplex talking circuit, but transmission signals are also sometimes difficult to hear.
The present application provides a single-transducer full duplex talking circuit combining an analog bridge circuit and a digital signal processing circuit using a single transducer having a receiving and transmitting function. The transducer is isolated from the external environment to a certain extent and can therefore block external noise and wind noise which obstruct talking since. As described above, it is possible to sufficiently compensate for the deterioration of the frequency characteristics of the transmission signal wherein the echo canceling function operates adequately even in cases where various characteristics including the strength of a transmission signal change from moment to moment and in cases in which the frequency characteristics of a transmission signal that is input into the single transducer are dramatically diminished due to the acoustic transfer characteristics of the human body.
A single-transducer full duplex talking circuit having a receiving and transmitting function, together with an analog signal processing circuit, a digital signal processing circuit, a coefficient updating algorithm, a system identification and learning correction intensity compensation algorithm, an erroneous correction detection and simultaneous talking detection algorithm, and an identification and learning algorithm which enable the full duplex talking circuit, is provided.
The analog signal processing circuit includes a bridge circuit containing ZT and the digital signal processing circuit cancels echo (leakage of reception signals into transmission signals through ZT) with a transfer function identification filter which simulates transfer characteristics including those of the analog signal processing circuit. The digital signal processing circuit further includes the series of algorithms (a coefficient updating algorithm, a system identification correction intensity calculation algorithm, an erroneous calculation detection and simultaneous talking detection algorithm, and a transfer function identification filter learning algorithm) which determine the transfer function identification filter coefficient by repeated convergence.
The single-transducer full duplex talking circuit includes connecting terminals for connecting to an external digital circuit, a digital signal processing circuit, a D/A converter DAC, an A/D converter ADC, and an analog signal processing circuit. The connecting terminals for an external digital circuit include an input terminal DIN into which a digital reception input signal is input, an output terminal DOUT into which a digital transmission output signal is output, and a learning activation input terminal ILN.
Further, the analog signal processing circuit includes an analog differential output amplifier ADO which amplifies the output from the D/A converter DAC, a bridge circuit consisting of first, second, and third resistors R1, R2, and R3, and a single transducer which are driven by the output of the analog differential output amplifier ADO. An analog differential input amplifier ADI amplifies an equilibrium signal output of the bridge circuit, wherein an analog output signal of the analog differential input amplifier ADI is supplied to the A/D converter (ADC).
In addition, the digital signal processing circuit is provided with a signal generator (SG), a second multiplier (MUL2) which multiplies the input from the signal generator SG by a signal volume coefficient register RSGV. A first high pass filter HPF1 receives the digital reception input signal through the input terminal DIN. A first multiplier (MUL1) multiplies the output of the high pass filter HPF1 by a reception volume coefficient RRXV. An adder ADD adds the output of the first multiplier MUL1 and the output of the second multiplier MUL2. The output of the adder ADD is supplied to the D/A converter DAC which converts it into an analog signal. A first delayer and power calculator DL1 delays the output signal of the adder ADD and calculates the moving average power. A second signal delayer and power calculator DL2 delays the output of the first signal delayer and power calculator DL1 and calculates the moving average power. A delayed signal memory XA[k] sequentially stores the output of the second signal delayer and power calculator DL2. A transfer function identification filter FILID receives the output of the delayed signal memory XA[k] and a first filter coefficient memory HA[k] stores the filter coefficient HA[k] of the transfer function identification filter FILID. A second high pass filter HPF2 receives the output of the A/D converter ADC and a fourth signal delayer DL4 receives the output of the second high pass filter HPF2. A subtracter (SUB) subtracts the output of the transfer function identification filter FILID from the output of the fourth signal delayer DL4 and a fourth multiplier MUL4 multiplies the output of the subtracter SUB by a transmission volume coefficient RTXV. A third signal delayer and power calculator DL3 delays the output of the fourth multiplier MUL4 and calculates the moving average power. An equalization filter FILEQ receives the output of the third signal delayer and power calculator DL3 and a second filter coefficient memory HEQ[k] stores the filter coefficient HEQ[k] of the equalization filter FILEQ. A transmission output terminal DOUT is driven by a digital transmission output signal output from the equalization filter FILEQ.
The first filter coefficient (also called HA[k] hereafter) corresponding to the transfer function identification filter FILID is stored in the first filter coefficient memory HA[k] and identifies the transfer function from the input end of the D/A converter DAC to the output end of the second high pass filter HPF2 via the analog signal processing circuit.
In the analog signal processing circuit, the bridge circuit is set to an equilibrium condition using the absolute value of the average impedance in the signal band of the reception signal (differential output signal of the analog differential output amplifier ADO) which drives the transducer ZT when the transducer ZT is in operation. The third resistor R3 is configured with fixed resistance, variable resistance, or electronically variable resistance in order to satisfy the equilibrium condition. The digital reception input signal is divided by the resistance from the differential output of the differential output amplifier via the D/A converter DAC and is converted from an electrical signal to an acoustic signal by the transducer ZT.
In the analog signal processing circuit, the voltage obtained by dividing the output of the differential output amplifier ADO with the first resistor R1 and the second resistor R2 is used as one input signal. The sum of the voltage obtained by dividing the output of the differential output amplifier with the third resistor R3 and the transducer ZT and the voltage converted to electromotive force from transmission acoustic vibration by the transducer ZT is used as another input signal. A differential signal of these signals is amplified by the differential input amplifier ADI.
The digital signal processing circuit has a function in which the first filter coefficient HA[k] corresponding to the transfer function identification filter FILID is dynamically corrected in accordance with changes in the transfer function due to changes in acoustic impedance when the transducer ZT is in operation.
In the digital signal processing circuit, the second filter coefficient (also called HEQ[k] hereafter) corresponding to the equalization filter FILEQ stored in the second filter coefficient memory HEQ[k] is a tap coefficient which corrects acoustic inconsistencies in electrical signals generated by the transducer ZT due to transmission acoustic vibration. The transmission signal is adjusted such that it has acoustic characteristics similar to the acoustic vibration generated from the actual sound source (in other words, the vicinity of the mouth of the person speaking).
The digital signal processing circuit also includes a correction intensity coefficient register Rmu which holds a correction coefficient mu. A third multiplier MUL3 multiplies the correction coefficient mu by an error signal err, which is the output of the subtracter SUB. A coefficient updating algorithm ALUPD updates the first filter coefficient HA[k] corresponding to the transfer function identification filter FILID based on the output of the third multiplier. The coefficient updating algorithm ALUPD supplies the first filter coefficient HA[k] to the transfer function identification filter FILID and updates the first filter coefficient HA[k] as a result of the convergence of this repeated computation.
The digital signal processing circuit is further provided with a system identification correction intensity calculation algorithm ALmu which dynamically controls the convergence time and convergence error of the repeated computation of the filter coefficient HA[k] of the transfer function identification filter FILID using the first moving average power value PW1.
The digital signal processing circuit is further provided with an erroneous correction detection and simultaneous talking detection algorithm ALDB having a function which, when updating the first filter coefficient HA[k], assesses whether to dynamically update the coefficient by comparing the second moving average power value PW2 and the third moving average power value PW3 and detects erroneous correction.
The digital signal processing circuit is further provided with a transfer function identification filter learning algorithm ALLN having a function which, when the error signal err exceeds a certain constant value, is forcibly activated as it is considered to be in the erroneous correction state or is forcibly activated from the outside through the learning activation input terminal ILN. The learning algorithm generates a standard signal using the signal generator SG, reactivates the coefficient updating algorithm ALUPD, and recalculates the first filter coefficient HA[k] corresponding to the transfer function identification filter FILID.
The single-transducer full duplex talking circuit includes a relatively small-scale analog signal processing circuit. The digital signal processing circuit is further provided with components such as a coefficient updating algorithm, a system identification correction intensity calculation algorithm, an erroneous correction detection and simultaneous talking detection algorithm, a transfer function identification filter learning algorithm, and an equalization filter. The echo canceling function sufficiently compensates for the deterioration of the frequency characteristics of the transmission signal, even in cases in which various characteristics including the strength of the transmission signal change from moment to moment and in cases in which the frequency characteristics are dramatically diminished due to the acoustic transfer characteristics of the human body. Moreover, recent advances in analog/digital technology enable the hardware that realizes all of this to be contained in an ear piece.
Optimal modes for carrying out the single-transducer full duplex talking circuit will be described in detail hereinafter with reference to the drawings.
Single-transducer Full Duplex Talking Circuit Configuration Example.
The analog signal processing circuit and the digital signal processing circuit of the present invention will be described with reference to
The digital signal processing circuit has a first high pass filter HPF1, a first multiplier MUL1, a reception volume coefficient register RRXV, a signal generator SG, a second multiplier MUL2, a signal volume coefficient register RSGV, and an adder ADD. The digital signal processing circuit also includes a first signal delayer and power calculator DL1, a second signal delayer and power calculator DL2, a transfer function identification filter FILID, a first delayed signal memory XA[k], and a first filter coefficient memory HA[k]. Also included is a second high pass filter HPF2, a fourth signal delayer DL4, a subtracter SUB, a fourth multiplier MUL4, a transmission volume coefficient register RTXV, a third signal delayer and power calculator DL3, an equalization filter FILEQ, and a second filter coefficient memory HEQ[k]. Also included is a third multiplier MUL3, a correction intensity coefficient register Rmu, an erroneous correction detection and simultaneous talking detection algorithm ALDBL, a coefficient updating algorithm ALUPD, a system identification correction intensity calculation algorithm ALmu, and a transfer function identification filter learning algorithm ALLN.
In the following descriptions, the circuit blocks representing components such as reception volume coefficient register RRXV and first delayed signal memory XA[k] and the signals constituting the content of these components are represented by the same symbols (for example, RRXV and XA[k]) for the sake of convenience.
The digital reception input signal applied to input terminal DIN is input into first multiplier MUL1 through first high pass filter HPF1, and after it is multiplied by reception volume coefficient RRXV, it is input into adder ADD and added to the output of second multiplier MUL2 to form a signal spk. Signal spk is split into two parts; one is input into D/A converter DAC, while the other is input into first signal delayer and power calculator DL1. The first signal delayer and power calculator DL1 calculates the first moving average power value PW1, which is the moving average power of the signal passing through DL1.
The output of D/A converter DAC is input into differential output amplifier ADO, where it is amplified to a power level sufficient to drive transducer ZT, and is output to differential output “+” and differential output “−”. Differential output “+” is split into two parts, and one signal pathway is connected to differential output “−” from differential output “+” through transducer ZT via resistor R3.
The other signal pathway is connected to differential output “−” from differential output “+” via resistors R1 and R2. In addition, differential input “+” and the differential input “−”, are the two input terminals of differential input amplifier ADI, and are connected to the junction point of resistor R3 and transducer ZT and the junction point of resistor R1 and resistor R2, respectively. The output terminal of differential input amplifier ADI is input into A/D converter ADC.
The output of first signal delayer and power calculator DL1 passes through second signal delayer and power calculator D2 to form signal src and updates first delayed signal memory XA[k]. This is processed by transfer function identification filter FILID using first delayed signal memory XA[k] and first filter coefficient memory HA[k], and the output becomes signal out. The second signal delayer and power calculator DL2 calculates the second moving average power value PW2, which is the moving average power of the signal passing through DL2.
The output signal of A/D converter ADC is input into fourth signal delayer and power calculator DL4 to form signal ref. Signal out is subtracted from signal ref by subtracter SUB to form signal err, which is input into fourth multiplier MUL4 and multiplied by reception volume coefficient RTXV to form signal mic. Signal mic is input into third signal delayer and power calculator DL3, and third signal delayer and power calculator DL3 calculates the third moving average power value PW3, which is the moving average power of the signal passing through DL3. The output processed by equalization filter FILEQ using the output of third signal delayer and power calculator DL3 and second filter coefficient memory HEQ[k] is output into digital transmission output signal terminal DOUT.
System identification correction intensity calculation algorithm ALmu performs calculations using first moving average power value PW1 and updates signal volume coefficient register RSGV and correction intensity coefficient register Rmu.
Erroneous correction detection and simultaneous talking detection algorithm ALDBL performs calculations using second moving average power value PW2 and third moving average power value PW3, and it thereby indicates to coefficient updating algorithm ALUPD whether or not the coefficients have been updated and detects the erroneous correction state. Signal err is input into third multiplier MUL3, where it is multiplied by correction intensity coefficient Rmu, and first filter coefficient memory HA[k] is updated by coefficient updating algorithm ALUPD.
External connections using analog signals are also enabled by replacing digital reception input terminal DIN and digital transmission output terminal DOUT, which are used as external connection circuits, with an A/D converter and a D/A converter, respectively.
All of the digital signal processing described above is performed in sync with the sample clock. Accordingly, in digital signal processing, all operations are performed once for each sample clock. Therefore, as long as the method used is one with which all digital signal processing can be completed in one sampling period, this digital signal processing circuit may be configured with one or multiple units of random logic, FPGA, ASIC, DSP, or CPU, and each circuit block of this digital signal processing circuit may be realized by either hardware or software.
An audio digital input signal is input into digital reception signal DIN. Low pass noise contained in the direct current component and in the audio input signal are removed from the audio input signal by first high pass filter HPF1, and this is corrected to a signal amplitude level suitable for the signal processing of later stages by the value stored in reception volume coefficient register RRXV and multiplier MUL1.
Meanwhile, signal generator SG generates a sweep signal which sweeps white noise or the entire band through which the signal passes as necessary. This is corrected to a signal amplitude level suitable for the signal processing of later stages by the value stored in signal volume coefficient register RSGV and second multiplier MUL2. These two signals are added using adder ADD to generate signal spk.
Output signal spk of adder ADD is split into two signal pathways, one of which becomes the input data of D/A converter DAC, and after this is digital/analog converted and is amplified to a signal level capable of adequately driving the bridge circuit by differential output amplifier ADO, it is output into the bridge circuit. Differential output amplifier ADO is for supplying a large amount of signal power with the bridge circuit when driving at low voltage, and any single output amplifier may be used as long as a sufficient driving voltage can be secured. In this case, it can be used by grounding the differential output “−” side of the differential output amplifier.
The bridge circuit consists of resistors R1, R2, and R3 and transducer ZT. The condition for minimizing the effects of the output of the differential output amplifier on the positive and negative input signals input from the bridge circuit into differential input amplifier ADI (differential input “+” and differential input “−”) is the case in which the following (M
R1:R2=R3:ZT (M
Since a device similar to a moving coil or moving core type receiver is used, the impedance of a typical transducer ZT is not a pure resistance, but is instead the composite impedance of the resistance component and the impedance component, and the composite impedance changes in a non-linear fashion depending on the frequency. Thus, the bridge circuit is not in the complete equilibrium state throughout the entire band through which signals pass.
However, with a typical transducer ZT, the impedance component is miniscule in comparison to the resistance component, so the portion of the input voltage of differential input amplifier ADI resulting from the output of differential output amplifier ADO can be suppressed by approximately 30-50 dB from the output voltage of differential output amplifier ADO.
In this embodiment, all three resistors R1-R3 of the bridge are represented as pure resistors, but each of the resistors (resistor R1, in particular) may be a series-parallel circuit comprising a resistor and a capacitor, and a series-parallel circuit comprising a resistor and a capacitor may also be inserted into transducer ZT in parallel. By fine-tuning the resistance and capacitance to suit the environment and the user, the convergence of the digital circuit operations described later can be more efficiently achieved.
On the other hand, the electromotive force generated as a result of transmission to transducer ZT is reduced by the parallel resistance of R3 and ZT, but the voltage generated at both ends of transducer ZT is extracted directly to the differential output of the bridge circuit. Therefore, the substantially damped output voltage of differential output amplifier ADO and the voltage generated at both ends of transducer ZT are added, and in this form they are input into differential input amplifier ADI and amplified to form an input signal of A/D converter ADC.
Since the voltage generated at both ends of transducer ZT is extremely weak, the damped output voltage of differential output amplifier ADO sometimes has a larger amplitude at this point.
The ratio of R3 and ZT affects the energy efficiency of transducer ZT with respect to the output of differential output amplifier ADO. The input energy efficiency when R3 and ZT are equal is 50%, and the acoustic pressure conversion energy efficiency of the reception signal decreases drastically when R3 is greater than ZT. Conversely, the voltage generated at both ends of transducer ZT by the transmission voltage pressure signal decreases drastically when R3 is smaller than ZT. Taking these factors into consideration, settings close to R1=R2 and R3=ZT are considered ideal. Moreover, since thermal noise becomes prominent as the resistance increases, the parallel resistance of R1 and R2 reduces the S/N ratio of the transmission signal. In an actual setup, optimal resistances for R1, R2, and R3 are selected experientially while taking these factors into consideration.
Further, if the individual difference of the transducer ZT that is used is small, a fixed resistor can also be used for R3. However, if the individual difference of the transducer ZT that is used is large, it is possible to adjust the bridge balance by using a semi-fixed resistor for R3 or to add an automatic adjusting function which ensures that the third moving average power value PW3, which is obtained by measuring the signal power generated from signal generator SG with third signal delayer and power calculator DL3, is minimized by using an electronically controllable semi-fixed resistor for R3.
On the other hand, signal spk input into first signal delayer and power calculator DL1 from adder ADD is the same as the input signal input into D/A converter DAC, and this is delayed by a signal delay time equivalent to the signal delay time generated by the path consisting of D/A converter DAC (conversion delay), the bridge circuit (group delay), A/D converter ADC (conversion delay) and high pass digital filter HPF2 (group delay) to form signal src. Simultaneously with this delay, first signal delayer and power calculator DL1 calculates the first moving average power value PW1 as a reference signal which will be necessary for system identification learning correction intensity calculation algorithm ALmu.
The second signal delayer and power calculator DL2, third signal delayer and power calculator DL3, and fourth signal delayer DL4 have the same delay time. The second moving average power value PW2 calculated by the second signal delayer and power calculator DL2 and the third moving average power value PW3 calculated by third signal delayer and power calculator DL3 are used as operation assessment criteria for erroneous correction detection and simultaneous talking detection algorithm ALDBL.
Transfer function identification filter FILID is a filter formed from a digital FIR filter, and it consists of delayed signal memory XA[k] in which the delay data of signal spk is saved and first filter coefficient memory HA[k] which holds the tap coefficient of the filter, wherefrom the results of performing convolution integration on two pieces of data are output. The convolution integral is given as the following (M
Here, n is the number of memory elements+1.
The first filter coefficient HA[k] of transfer function identification filter FILID is a tap coefficient of the FIR filter which identifies the transfer function of the signal pathway from D/A converter DAC to the bridge circuit, A/D converter ADC, and second high pass filter HPF2. Therefore, output out of transfer function identification filter FILID is a signal which identifies the bridge driving signal (in other words, the “substantially damped output voltage of differential output amplifier ADO” described above) remaining in signal ref which passed through second high pass filter HPF2 and fourth signal delayer DL4 from the A/D converter, so the residual signal, which is unnecessary for transmission, can be suppressed by performing subtraction on this signal using subtracter SUB, which enables the extraction of only signals generated by transmission to transducer ZT.
The transmission signal generated by transducer ZT, which is extracted as a result of subtraction by subtracter SUB, is adjusted to a signal amplitude level suitable for the signal processing of later stages up to digital transmission output signal terminal DOUT by fourth multiplier MUL4 using the value of transmission volume coefficient register RTXV to form signal mic, and this is input into equalization FILEQ after it is delayed by third signal delayer and power calculator DL3. The transmission signal of transducer ZT is corrected by the equalization filter such that it has appropriate acoustic frequency characteristics similar to the acoustic vibration generated from the actual sound source, and it is then output to digital transmission output signal terminal DOUT.
When the digital reception input signal input from input terminal DIN is −0 dB, in other words, when it is input on a full scale, signal spk passing through the first high pass filter and D/A converter DAC forms the output signal of differential output amplifier ADO and drives transducer ZT via resistor R3. Further, when resistors R1 and R2 are set to the same values while the value of resistor R3 is set to the absolute value (converted to a resistance component) of the average complex impedance within the operating frequency of transducer ZT and the full scale of the output signal of differential output amplifier ADO is presumed to be 0 dBm, the reception signal applied to transducer ZT is damped by one-half and becomes −6 dBm. On the other hand, presuming that the transmission signal generated by transducer ZT is −80 dBm, the ratio of the reception and transmission signals generated at both ends of transducer ZT becomes 74 dB. In other words, a residual reception signal approximately 5000 times the transmission signal is present at both ends of transducer ZT.
If the bridge circuit were completely balanced, the reception signal would not appear in the differential of the bridge output, but since complete balance cannot be achieved, the residual reception and transmission signals are input as differential signals into both ends of differential input amplifier ADI.
Assuming a reception signal suppression ratio of 40 dB in the bridge circuit, the reception signal remains at a level of −46 dBm while the transmission signal generated by transducer ZT is −80 dBm, so the residual reception signal is still approximately 34 dB larger than the transmission signal.
When the gain of differential input amplifier ADI is presumed to be 40 dB and the full scale of A/D converter ADC is presumed to be 0 dBm, the residual reception signal is −6 dB and the transmission signal is −40 dB. This signal generates signal ref as it passes through second high pass filter HPF2 and fourth signal delayer DL4.
As described above, output spk of adder ADD passes through first signal delayer and power calculator DL1 and second signal delayer and power calculator DL2 to form signal src, and, receiving this signal, transfer function identification filter FILID sequentially identifies the transfer characteristics of the signal pathway from D/A converter DAC to second high pass filter HPF2 and generates signal out, which is a signal that is roughly equivalent to the residual reception signal. As a result of the subtraction of signal out from the output of second high pass filter HPF2 by subtracter SUB, the residual reception signal is suppressed by approximately 60 dB, and almost only the transmission signal is output from subtracter SUB.
In this state, the transmission signal is −40 dB while the residual reception signal is −66 dB, and the ratio of the transmission signal and the residual reception signal is approximately −26 dB, so it is essentially possible to retrieve the transmission signal alone. Further, in order to adapt the output of subtracter SUB to the amplitude level of digital transmission signal DOUT, it is input into fourth multiplier MUL4, where it is multiplied by transmission volume coefficient RTXv and amplified by approximately 35 dB to form signal mic. Then, after the acoustic characteristics of transducer ZT are adjusted by the equalization filter, the signal is output to output terminal DOUT of the digital transmission output signal.
In other words, while reception signal suppression is approximately 20-40 dB with typical system identification methods used for echo cancellation, the present invention is able to suppress reception signals obstructing transmission signals by 90 dB or more in a single-transducer full duplex talking circuit by combining the simple analog signal processing and advanced digital signal processing described above.
Coefficient updating algorithm ALUPD is an algorithm which sequentially corrects first filter coefficient HA[k] of transfer function identification filter FILID using delayed signal XA[k] and the value obtained by multiplying error signal err, which is the output of subtracter SUB, by the correction coefficient mu held by correction intensity coefficient register Rmu with third multiplier MUL3. Defining each element of the present delayed signal memory corresponding to input presumed to have constant signal strength and a stochastic process with a steady Gaussian distribution as XA[k], each element of the present first filter coefficient as HA[k]n, and each element of the first filter coefficient after updating as HA[k]n+1, a single tap coefficient update is performed using the algorithm of the following M
HA[k]n+1=HA[k]n+XA[k]×err·mu (M
By repeating this calculation, the first filter coefficient HA[k] converges to the first filter coefficient which identifies the transfer function of the targeted signal pathway. The value of mu is related to the convergence time and the convergence error, and if mu is increased, the convergence time is quickened but the convergence error increases. Further, if XA[k] does not satisfy a steady stochastic process, HA[k] may diverge without converging or the convergence time may become long, depending on the value of mu. Moreover, coefficient updating algorithm ALUPD is not limited to this formula, and this can be replaced by various system identification algorithms based on other stochastic processes.
System identification correction intensity calculation algorithm ALmu is an algorithm which calculates the appropriate value for mu held by correction intensity coefficient register Rmu, which is used by coefficient updating algorithm ALUPD. An ordinary digital reception input signal DIN is typically an audio signal which has signal strength that changes with time and has a chromatic spectrum without a steady Gaussian distribution, so it cannot be presumed that its delayed signal XA[k] will have constant signal strength and a stochastic process with a steady Gaussian distribution.
Therefore, the calculation of first filter coefficient HA[k] described above is performed with the calculation algorithm shown in the following M
Here, α is a constant and β is a miniscule value for ensuring that the denominator of the formula is not 0. In the case of a series of signals in which the reference input has a stochastic process with a steady Gaussian distribution and in the case of an audio signal with a chromatic spectrum without a Gaussian distribution, since the convergence time and the convergence error substantially differ depending on the selection of constant α, constant α is set to a value based on actual measurements taken when mounted. Further, system identification correction intensity calculation algorithm ALmu is not limited to this formula, and this can be replaced by various algorithms for system identification based on other stochastic processes.
Cases may exist in which the signal power of digital reception input signal DIN is continuously small or in cases in which there is no signal, for example, first filter coefficient HA[k] cannot be dynamically calculated. Accordingly, system identification correction intensity calculation algorithm ALmu can perform appropriate system identification by increasing the value of signal volume coefficient register RSGV and overlaying a test signal from signal generator SG with the reception signal. Further, system identification correction intensity calculation algorithm ALmu is provided with a function which switches the value of signal volume coefficient register RSGV to the amplitude level for learning when erroneous correction detection and simultaneous talking detection algorithm ALDBL, which is described below, detects erroneous correction.
Erroneous correction detection and simultaneous talking detection algorithm ALDBL assesses the level of the transmission signal strength of transducer ZT (in other words, third moving average power value PW3 calculated by third signal delayer and power calculator DL3) and the level of the digital reception input signal strength (in other words, second moving average power value PW2 calculated by signal delayer and power calculator DL2) added to error signal err used by coefficient updating algorithm ALUPD (in other words, error signal err which is the output of subtracter SUB) and detects the state in which transmission and reception are performed simultaneously (simultaneous talking state). In this case, the algorithm temporarily suspends coefficient updating algorithm ALUPD and ensures that the transmission signal component contained in error signal err does not (erroneously) dynamically update first filter coefficient HA[k] (erroneous correction prevention).
If error signal err becomes extremely large, exceeding a certain constant value, it is considered to be in the erroneous correction state. Transfer function identification filter learning algorithm ALLN described below is then forcibly activated and first filter coefficient HA[k] of transfer function identification filter FILID is recalculated. Transfer function identification filter learning algorithm ALLN can be forcibly activated externally through learning activation input terminal ILN.
Transfer function identification filter learning algorithm ALLN corrects first filter coefficient HA[k] of transfer function identification filter FILID by generating a standard signal approximating a stochastic process with a steady Gaussian distribution using signal generator SG and then reactivating coefficient updating algorithm ALUPD. Normal operations are resumed when the prescribed transfer function identification is complete.
Further, the standard signal generated by signal generator SG uses a binary pseudorandom number based on an “M sequence” and uses the two values 1.0 and −1.0. Here, a binary pseudorandom number based on an “M sequence” is a binary pseudorandom number generated by a one-bit number sequence generated by the following linear recurrence formula, M
Xn=(Xn−p)XOR(Xn−q)|p>q (M
In this formula, the value of each term is 0 or 1, and the symbol of operation “XOR” is exclusive OR. In other words, the n-th term is obtained by performing the XOR operation n the (n−p)th term and the (n−q)th term. The state of Xn generates a binary pseudorandom number sequence consisting of a 0 or a 1 for each calculation in Mathematical Formula 5. These two values are used by signal generator SG after they are converted to 1.0 and −1.0.
The standard signal generated by signal generator SG is not limited to this formula, and a standard signal approximating another stochastic process with a steady Gaussian distribution can also be used. For example, the frequency sweep signal provided by the following Mathematical Formula 6 can be used repeatedly. Defining the standard signal sequence as t[i], the signal data for each element can be calculated with the following M
Here, L and k are parameters representing the sweep period and frequency, respectively. This signal generates a test signal which yields a phase proportional to the square of the frequency. Moreover, although a unit impulse is sometimes used as a standard signal, unit impulses have smaller average power levels and require time for system identification in comparison to the two types of standard signals described above, and they sometimes result in system identification with a poor S/N ratio.
Further, signal delayer and power calculators DL1, DL2, DL3, and DL4 or delayed signal memory XA[k] operate according to the following such algorithm. Presuming that the number of delayed memory elements of signal delayer DL is n+1 and defining each element of delayed memory as DL[k], the input digital signal data as DLIN, and the output digital signal data as DLOUT, the calculations of the signal delayer are executed using the algorithm of the following Mathematical Formula 7.
DLOUT=DL[n]
DL[k−1]=DL[k]|0≦k≦n
DL[0]=DLIN (M
In addition, defining the moving average power value output from the power calculator as PW, the moving average power value PW is calculated by the algorithm of the following M
In the initial state, coefficient updating algorithm ALUPD is not operating, so the sum of the residual reception signal and the transmission signal generated at both ends of differential input amplifier ADI is output directly to the output of digital transmission output signal DOUT.
When learning activation input terminal ILN is activated, transfer function identification filter learning algorithm ALLN is activated and the learning sequence of FILID is begun. Digital transmission output signal DOUT is set to the signal-less state since RTXV is set to 0, but internally the transfer characteristics of the signal pathway from D/A converter DAC to second high pass filter HPF2 are sequentially identified by the test signal from signal generator SG and coefficient updating algorithm ALUPD, and first filter coefficient HA[k] of transfer function identification filter FILID is thus converged and corrected. When identification is complete, the test signal from signal generator SG is suspended and RTXV is reverted to the standard setting.
Continuing, the dynamic update of first filter coefficient HA[k] of transfer function identification filter FILID is begun using system identification correction intensity calculation algorithm ALmu and coefficient updating algorithm ALUPD.
After dynamically assessing the levels of the third moving average power value PW3 originating from the transmission signal and the second moving average power value PW2 originating from the reception signal, erroneous correction detection and simultaneous talking detection algorithm ALDBL detects the state in which transmission and reception are performed simultaneously (simultaneous talking state) and suspends or resumes coefficient updating algorithm ALUPD. Due to this function, the erroneous correction of first filter coefficient HA[k] of transfer function identification filter FILID in the simultaneous talking state is prevented.
As described above, by combining appropriate algorithms, it is possible to suppress reception signals obstructing transmission signals by 90 dB or more within a few seconds after full duplex talking begins in a single-transducer full duplex talking circuit, and it is possible to maintain this state for long periods of time by using erroneous correction detection and simultaneous talking detection algorithm ALDBL.
Moreover, the single transducer having a receiving and transmitting function refers to a reversible transducer which has the property that it generates an acoustic pressure signal proportional to a vibration voltage by applying the vibration voltage between both terminals of transducer ZT and generates a vibration voltage proportional to the vibration acoustic pressure between both terminals of transducer ZT by applying vibration acoustic pressure to transducer ZT. Using this conversion function, the single transducer is typically used to mutually convert electrical and acoustic signals. Examples of single transducers having this receiving and transmitting function include moving coil type speaker-microphones and moving core type speaker-microphones.
The analog signal processing circuit, digital signal processing circuit, coefficient updating algorithm, system identification learning correction intensity calculation algorithm, erroneous correction detection and simultaneous talking detection algorithm, and identification learning algorithm of the present invention were described above, but the above descriptions were given to facilitate an understanding of the present invention and do not limit the present invention. The present invention can be modified and improved without deviating from its purpose.
The system described above can use dedicated processor systems, micro controllers, programmable logic devices, or microprocessors that perform some or all of the operations. Some of the operations described above may be implemented in software and other operations may be implemented in hardware.
For the sake of convenience, the operations are described as various interconnected functional blocks or distinct software modules. This is not necessary, however, and there may be cases where these functional blocks or modules are equivalently aggregated into a single logic device, program or operation with unclear boundaries. In any event, the functional blocks and software modules or features of the flexible interface can be implemented by themselves, or in combination with other operations in either hardware or software.
Having described and illustrated the principles of the invention in a preferred embodiment thereof, it should be apparent that the invention may be modified in arrangement and detail without departing from such principles. Claim is made to all modifications and variation coming within the spirit and scope of the following claims.
This application is a continuation in part application of U.S. patent application Ser. No. 10/595,757, filed May 9, 2006 and U.S. patent application Ser. No. 10/595,758, filed May 9, 2006 which is incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
1224331 | Smith | May 1917 | A |
3114105 | Neumiller | Dec 1963 | A |
3370236 | Walker | Feb 1968 | A |
3781492 | Cragg et al. | Dec 1973 | A |
3829624 | Goodin et al. | Aug 1974 | A |
2955140 | Stephens et al. | May 1976 | A |
4002860 | Terai et al. | Jan 1977 | A |
4052562 | Andersen | Oct 1977 | A |
4065646 | Schuh | Dec 1977 | A |
4082919 | Day et al. | Apr 1978 | A |
4087636 | Akiyama et al. | May 1978 | A |
4156800 | Sear | May 1979 | A |
4280018 | Lazarus et al. | Jul 1981 | A |
4403120 | Yoshimi | Sep 1983 | A |
4470127 | Thompson | Sep 1984 | A |
4516200 | Thompson | May 1985 | A |
4519029 | Thompson | May 1985 | A |
4598396 | Upp et al. | Jul 1986 | A |
4629829 | Puhl et al. | Dec 1986 | A |
4635285 | Coombes | Jan 1987 | A |
4644330 | Dowling | Feb 1987 | A |
4668842 | Yokoyama et al. | May 1987 | A |
4691313 | Iwata | Sep 1987 | A |
4695823 | Vernon | Sep 1987 | A |
4696045 | Rosenthal | Sep 1987 | A |
4741018 | Potratz et al. | Apr 1988 | A |
4833719 | Carme et al. | May 1989 | A |
4837829 | Lobb | Jun 1989 | A |
4912758 | Arbel | Mar 1990 | A |
4941123 | Thompson | Jul 1990 | A |
4972491 | Wilcox | Nov 1990 | A |
5007046 | Erving et al. | Apr 1991 | A |
5099519 | Guan | Mar 1992 | A |
5115471 | Liden | May 1992 | A |
5118309 | Ford | Jun 1992 | A |
5168522 | Simanis et al. | Dec 1992 | A |
5172410 | Chace | Dec 1992 | A |
5202918 | White | Apr 1993 | A |
5235637 | Kraz et al. | Aug 1993 | A |
5265264 | Dzung et al. | Nov 1993 | A |
5287406 | Kakuishi | Feb 1994 | A |
5307405 | Sih | Apr 1994 | A |
5311144 | Grasset | May 1994 | A |
5333205 | Bogut et al. | Jul 1994 | A |
5335286 | Carlson et al. | Aug 1994 | A |
5379450 | Hirasawa et al. | Jan 1995 | A |
5393989 | Gempe et al. | Feb 1995 | A |
5410595 | Park et al. | Apr 1995 | A |
5420930 | Shugart, III | May 1995 | A |
5465298 | Wilkison et al. | Nov 1995 | A |
5471666 | Sugiyama et al. | Nov 1995 | A |
5479474 | Schwartzman et al. | Dec 1995 | A |
5586193 | Ichise et al. | Dec 1996 | A |
5617450 | Kakuishi et al. | Apr 1997 | A |
5692059 | Kruger | Nov 1997 | A |
5708970 | Newman et al. | Jan 1998 | A |
5715309 | Bartkowiak | Feb 1998 | A |
D399206 | Yasutomi et al. | Oct 1998 | S |
5824966 | Leight | Oct 1998 | A |
D403681 | Lam | Jan 1999 | S |
D404035 | Delazzer | Jan 1999 | S |
5899973 | Bandara et al. | May 1999 | A |
5907538 | White | May 1999 | A |
D426880 | Leight | Jun 2000 | S |
6104824 | Ito | Aug 2000 | A |
6105714 | Lindgren | Aug 2000 | A |
6138790 | Leight | Oct 2000 | A |
6175633 | Morrill et al. | Jan 2001 | B1 |
D439574 | Katayama | Mar 2001 | S |
6233345 | Urwyler | May 2001 | B1 |
6278786 | McIntosh | Aug 2001 | B1 |
6311052 | Lenz | Oct 2001 | B1 |
6357292 | Schultz et al. | Mar 2002 | B1 |
6370245 | White | Apr 2002 | B1 |
D458244 | Masuda | Jun 2002 | S |
D458245 | Masuda | Jun 2002 | S |
6415034 | Hietanen | Jul 2002 | B1 |
6480610 | Fang et al. | Nov 2002 | B1 |
6760434 | Rezvani et al. | Jul 2004 | B1 |
6795549 | Ferianz et al. | Sep 2004 | B2 |
7072476 | White | Jul 2006 | B2 |
7826805 | Masuda | Nov 2010 | B2 |
7881483 | Masuda | Feb 2011 | B2 |
20020186858 | Masuda | Dec 2002 | A1 |
20030134600 | Picone et al. | Jul 2003 | A1 |
20030185403 | Sibbald | Oct 2003 | A1 |
20040072540 | Wilson et al. | Apr 2004 | A1 |
20040213427 | Yoon | Oct 2004 | A1 |
20070133442 | Masuda | Jun 2007 | A1 |
Number | Date | Country |
---|---|---|
1213847 | Jun 2002 | EP |
0719018 | Nov 2002 | EP |
2755561 | May 1998 | FR |
0032833 | Apr 1981 | JP |
03-054990 | Aug 1991 | JP |
07-058673 | Mar 1995 | JP |
08-256196 | Jan 1996 | JP |
09-288560 | Apr 1997 | JP |
09-140000 | May 1997 | JP |
11-275674 | Aug 1999 | JP |
2001060895 | Aug 1999 | JP |
11-069480 | Sep 1999 | JP |
2000-175285 | Jun 2000 | JP |
2001-060985 | Mar 2001 | JP |
2109408 | Apr 1998 | RU |
WO9323942 | Nov 1993 | WO |
WO 9727721 | Jul 1997 | WO |
WO 9820820 | May 1998 | WO |
WO 9836515 | Aug 1998 | WO |
WO 9845937 | Oct 1998 | WO |
WO 0207477 | Jan 2002 | WO |
WO03039191 | Aug 2003 | WO |
WO2005048572 | May 2005 | WO |
Number | Date | Country | |
---|---|---|---|
20080170515 A1 | Jul 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10595757 | May 2006 | US |
Child | 12054320 | US | |
Parent | 10595758 | May 2006 | US |
Child | 10595757 | US |