CIRCUITS AND METHODS FOR TIME-DELAY TO DIGITAL CONVERTERS

Abstract
In accordance with some embodiments, polarity-coincidence, adaptive time-delay estimation (PCC-ATDE), mixed-signal techniques are provided. In some embodiments, these techniques use 1-bit quantized signals and negative-feedback architectures to directly determine a time-delay between signals at analog inputs and convert the time-delay to a digital number.
Description
BACKGROUND

Time-delay estimations (TDE) are used to extract the time difference of arrival between microphones in sound-source localization systems.


The standard approach to TDE uses the direct cross-correlation (DCC) function. When using the DCC function, for each TDE, time frames of the input signals are stored and all the points of the DCC function are calculated. The argument of the maximum of the DCC corresponds to the intersignal time delay between the signal inputs. With a sampling frequency above 50 KS/s, the storage of the frames and the arithmetic operations to calculate the DCC values are a roadblock towards achieving a sub-μW implementation as is needed in mobile, wearable, or IoT applications.


The low complexity of adaptive time-delay estimation (ATDE) techniques makes them an attractive approach to TDE, but these techniques still require a high-resolution ADC after the sensors. Thus, these are also not suitable for many low power applications


Bio-inspired silicon cochlea estimate the time difference in input signals by translating audio stimulus into asynchronous events. However, the power consumption of bio-inspired silicon cochlea is in the μW range, which makes such cochlea unsuitable for certain low power applications.


Accordingly, new mechanisms for TDE are desirable.


SUMMARY

In accordance with some embodiments, circuits and methods for time-delay to digital converters are provided. In some embodiments, circuits for a time-delay to digital converter are provided, the circuits comprising: a first microphone having a first output; a second microphone having a second output; a first one-bit analog-to-digital converter having a first input coupled to the first output and having a third output; a second one-bit analog-to-digital converter having a second input coupled to the second output and having a fourth output; a first variable time delay having a third input coupled to the third output, a fourth input, and a fifth output, wherein the fourth input controls a delay amount of the first variable time delay; a second variable time delay having a fifth input coupled to the fourth output, a sixth input, and a sixth output, wherein the sixth input controls a delay amount of the second variable time delay; a first mixer having a seventh input coupled to the fifth output, an eighth input coupled to the sixth output, and a seventh output; a third variable time delay having a ninth input coupled to the sixth output, and a eighth output; a second mixer have a tenth input coupled to the fifth output, and eleventh input coupled to the eighth output, and a ninth output; a subtractor having a twelfth input coupled to the seventh output, a thirteenth input coupled to the 9th output, and a tenth output; an accumulator having a fourteenth input coupled to the tenth output, and an eleventh output; an attenuator having a fifteenth input coupled to the eleventh output, and a twelfth output; a differential splitter having a sixteenth input coupled to the twelfth output, a thirteenth output, and a fourteenth output; a first adder having a seventeenth input coupled to the thirteenth output, an eighteenth input coupled to an offset signal, and a fifteenth output coupled to the sixth input; and a second adder having a nineteenth input coupled to the fourteenth output, an twentieth input coupled to the offset signal, and a sixteenth output coupled to the fourth input.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram illustrating an example of the principle of a polarity-coincidence, adaptive time-delay estimation (PCC-ATDE) mechanism in accordance with some embodiments.



FIG. 2 is an example of a graph of possible PCCM1,M2 values in accordance with some embodiments.



FIG. 3 is an example of a circuit for a PCC-ATDE mechanism in accordance with some embodiments.



FIG. 4 is an example of block diagram illustrating how variable delays can be determined in accordance with some embodiments.



FIG. 5 is an example of a block diagram of a time-discrete implementation using latched comparators, digital delay cells, XORs, adders, and dividers in accordance with some embodiments.



FIG. 6 is an example of two graphs showing values for M1(t), M2(t), Mixer1[n]-Mixer2[n], and FM1,M2[Δ] in accordance with some embodiments.



FIG. 7 is an example of graphs showing values for PCC(τ) and Fx,x(D-Δ) in accordance with some embodiments.



FIG. 8 is an example of delay domain model in accordance with some embodiments.



FIG. 9 is an example of a graph of PCCx,x vs. τ in accordance with some embodiments.



FIG. 10 is an example of chip implementation of a PCC-ATDE mechanism in accordance with some embodiments.



FIG. 11 is an example of latched comparator in accordance with some embodiments.



FIG. 12 is an example of sub-threshold level shifter in accordance with some embodiments.





DETAILED DESCRIPTION

In accordance with some embodiments, polarity-coincidence, adaptive time-delay estimation (PCC-ATDE), mixed-signal techniques are provided. In some embodiments, these techniques use 1-bit quantized signals and negative-feedback architectures to directly determine a time-delay between signals at analog inputs and convert the time-delay to a digital number.


In a time delay estimation (TDE), the sampling frequency of the data converters FS defines the resolution. The noise from approaching automobiles or other vehicles has dominant spectral components below 250 Hz. To support a −1 ms to +1 ms delay range with 8-bit resolution for such noise-like sources, the audio signal needs to be sampled at >50 KS/s, i.e. 100× the Nyquist rate, in some embodiments.


Consider the outputs of two microphones, M1(t) and M2(t), which capture the signal of the single source x(t) at different positions in space:






M
1(t)=x(t)+n   (1)






M
2(t)=A.x(t−D)+n2(t)   (2)


where D is the time delay that the algorithm needs to determine, n1(t) and n2(t) are random noise, and A the gain (or attenuation) difference in the microphones. In prior mechanisms, the estimation of D requires computing the direct cross-correlation













DCC


M
1

,

M





2





(
τ
)


=


1
T





0
T




M
1



(
t
)





,



M
2



(

t
-
τ

)



dt










(
3
)







for many different T and then determining the argument of the peak:






D=argmax(DCCM1,M2(τ))   (4)


There are multiple ways to compute the DCCM1,M2, however, each is complex.


An alternative to using the DCC function for performing TDE is to use the polarity-coincidence correlation function (PCC):













PCC


M
1

,

M
2





(
τ
)


=


1
T





0
T



sgn


(


M
1



(
t
)


)





,


sgn


(


M
2



(

t
-
τ

)


)



dt










(
5
)







It is known that











PCC


M
1

,

M





2





(
τ
)


=


2
π




sin

-
1




(



DCC


M
1

,

M





2





(
τ
)



max


(


DCC


M
1

,

M





2





(
τ
)


)



)







(
6
)







hence argmax(PCCM1,M2)=argmax(DCCNM1,M2). Note that the computation of PCC only needs one-bit signals, in contrast to DCC which requires multi-bit signals.


Regardless of how one obtains DCCM1,M2 or PCCM1,M2, their computation involves storing a large frame of both M1(t) and M2(t), calculating and storing all the points of the cross-correlation within the TDE range, and finally searching for the argument of the peak.


In accordance with some embodiments, polarity-coincidence-correlation, adaptive, time-delay estimation (PCC-ATDE) approaches are provided. The PCC-ATDE approaches use only two values of a polarity-coincidence correlation function to close a negative feedback loop that continuously tracks intersignal delay.



FIG. 1 illustrates an example 100 of the principle of the PCC-ATDE in accordance with some embodiments. As shown, a loop is formed from blocks 102 and 104, subtractor 109, integrator 110, and attenuator 112. Only two points of the PCCM1,M2(τ) are calculated at boxes 102 and 104; box 102 with and argument A, with an output marked by a square 106, and box 104 with an argument Δ+τfix, with an output marked by a circle 108. To search for the D=argmax(PCCM1,M2), the loop takes the difference between the two PCCM1,M2 values using subtractor 109.



FIG. 2 illustrates an example 200 of a graph of possible PCCM1,M2 values in accordance with some embodiments. If the current Δ value is sufficiently close to the peak, the difference between PCCM1,M2(Δ) and PCCM1,M2(Δ+τfix) indicates whether Δ is smaller or larger than the argument of the peak. The integrator will continuously increase or decrease the value of Δuntil PCCM1,M2(Δ) and PCCM1,M2(Δ+τfix) have equal values, locking the loop at Δ=D−τfix/2, which gives a measurement of the desired intersignal delay D. If the values fall within box 202, then integrator 110 in FIG. 1 will increase the value of A. If the values fall within box 204, then Δ settles at D−τfix/2. If the values fall within box 206, then integrator 110 in FIG. 1 will decrease the value of Δ.


Attenuator 1/G 112 in FIG. 1 sets the speed and bandwidth of the loop.


A practical problem for the architecture in FIG. 1 is that to calculate the PCCM1,M2 values at blocks 102 and 104, a large frame of each input signal needs to be stored.


In accordance with some embodiments, this problem may be overcome using example circuit 300 of FIG. 3. As shown, in some embodiments, PCCM1,M2(Δ) and PCCM1,M2(Δ+τfix) can be extracted in the PCC-ATDE without storing signal frames. The analog microphone signals M1(t) and M2(t) are directly connected to comparators 302 and 304, which each act as a 1-bit analog to digital converter (ADC). In some embodiments, each of comparators 302 and 304 output a+1 if the microphone signal at the comparator's input is greater than zero, and a−1 otherwise.


The outputs of comparators 302 and 304 are then provided to variable-delay cells 306 and 308, respectively, which have delays of τvar1 and τvar2, respectively. The outputs of the variable delay cells produce signals M1d(t) and M2d(t):






M
1d(t)=sgn(x(t−τvar1)+n1(t−τvar1))   (7)






M
2d(t)=sgn(A.x(t−τvar2−D)+n2(t−τvar2))   (8)


As shown in FIG. 4, the variable delays τvar1 and τvar2 are defined such that Δ=τvar2−τvar1. And, since a variable delay line can only introduce positive delay values, an offset τoffset is added such that τvar1 and ∜var2 are always positive. When the loop settles, Δ corresponds to the time-delay estimation between the inputs, and can assume both positive and negative values depending on which input is ahead of the other.


Referring back to FIG. 3, next, M1d(t) and M2d(t) are multiplied by multiplier 310 to create VMIXER1(t). The average of VMIXER1(t) is the same as PCCM1,M2(Δ):












1
T






t
-
T

t





V

MIXER





1




(
t
)







dt



=


1
2









0
T



sgn


(


M
1



(
t
)


)





,



sgn


(


M
2



(

t
-
Δ

)


)



dt

:=


PCC


M
1

,

M





2





(
Δ
)







(
9
)







M2d(t) is further delayed by fixed delay 312 by a fixed value, τfix, and then multiplied by multiplier 314 with M1d(t) to create VMIXER2. The average VMIXER2 is PCCM1,M2(Δ+τfix). Note that the averages of the multipliers output, VMIXER1 and VMIXER2, do not need to be explicitly calculated.


The difference between VMIXER1 and VMIXER2 is then determined by subtractor 316. This will result in difference values of +2, 0, or −2.


Next, loop integrator 318 averages the difference values and attenuates the higher frequency components of these signals.


Attenuator 320 then receives the output of the integrator and produces an attenuated signal. The loop bandwidth, which is directly controlled by the attenuator, determines the effective length T of the averages calculated by the integrator.


Turning to FIG. 5, a block diagram of a time-discrete implementation using latched comparators, digital delay cells, XORs, adders, and dividers is shown in accordance with some embodiments. The two shaded areas have different functionalities: the section on the left is used to add a delay of Δ[n] to the microphone signals; the section on the right is used to determine Fx,x, which is a function of the intersignal time-delay of its input.


As shown in FIG. 5, the output Δ[n] at timestep n is given by:










Δ


[
n
]


=


Δ


[

n
-
1

]


+


1
G

·

(



Mixer
1



[
n
]


-


Mixer
2



[
n
]



)







(
10
)







As illustrated in FIG. 6, the result of the subtraction Mixer1[n]-Mixer2[n] is a fast-switching digital signal that can only assume values of −2,0,2. Since Mixer1[n]-Mixer2[n] has much higher frequency components than the PCC-ATDE loop in some embodiments, it can be decomposed into two components:





Mixer1[n]−Mixer2[n]=FM1,M2(Δ[n])+e[n]  (11)


where e[n] contains the high-frequency components, with average zero, and FM1,M2 is the average value of Mixer1[n]−Mixer2[n]. As in (9), it can be shown that Fm1,M2, is mathematically equal to the difference of two values of the PCCM1,M2 with argument Δ[n]+τfix and Δ[n]:











F


M
1

,

M
2





(

Δ


[
n
]


)


=





1
T






k
=

n
-
T


n







[



Mixer
1



[
n
]


-


Mixer
2



[
n
]



]



=


1
T






k
=

n
-
T


n



[




sgn


(


M
1



[

k
-


τ

var





1




[
k
]



]


)


·

sgn


(


M
2



[

k
-


τ

var





2




[
k
]



]


)



-


sgn


(


M
1



[

k
-


τ

var





2




[
k
]



]


)


·

sgn
(


M
2

[

k
-


τ

var





2




[
k
]


-

τ
fix


)

]



:=



PCC


M
1

,

M
2





(

Δ


[
n
]


)


-


PCC


M
1

,

M
2





(


Δ


[
n
]


+

τ
fix


)












(
12
)







Note that, assuming that the PCCM1,M2 and τfix are static, FM1,M2 is a function of the output Δ[n]. FM1,M2(Δ[n]) and e[n] can be substituted in (10) to provide:










Δ


[
n
]


=


Δ


[

n
-
1

]


+


1
G

·


F


M
1

,

M
2





(

Δ


[
n
]


)



+


1
G

·

e


[
n
]








(
13
)







e[n] does not introduce a DC error in Δ[n], but contributes as noise at the output. If one neglects e[n] and focuses on the low-frequency output of the loop, a non-linear feedback loop that continuously increases or decreases Δ[n] to keep FM1,M2(Δ[n])=0 is obtained.


Based on (13), a delay-domain model can be used to predict the behavior of the PCC-ATDE loop. The PCC-ATDE operates across multiple-domains. Delay-domain models can assist in understanding how the PCC-ATDE operates. In the PCC-ATDE, the function FM1,M2 [Δ] is responsible for a domain swap; the value of FM1,M2[Δ] is directly dependent on the difference between estimated time delay A and the intersignal time delay from the microphones D.


Since the only correlation between M1(t) and M2(t) comes from the source x(t), the polarity-coincidence correlation function between M1 and M2 can be approximated by the auto-polarity-coincidence correlation function of x(t) shifted by the intersignal delay D:






PCC
M

1

,M

2
[Δ]≈PCCx,x[Δ−D]  (14)


This approximation can be used to understand the contribution of the microphone delay D to the values of FM1,M2, resulting in the function Fx,x:










Δ


[
n
]


=


Δ


[

n
-
1

]


+


1
G

·


F

x
,
x




[


Δ


[
n
]


-
D

]



+


1
G

·

e


[
n
]








(
16
)







The approximation in (14) and Fx,x are illustrated in FIG. 7 in accordance with some embodiments. Examples of PCCM1,M2 and PCCx,x are overlapped for a band-limited noise x(t) (top left in FIG 7) and a sinusoidal x(t) (bottom left in FIG. 7). Next to each of them is the resulting Fx,x(D−Δ). Notice that Fx,x only depends on the source signal x(t) and the fixed delay τfix; and, since it is defined by the difference of two PCCx,x values spaced by τfix, it can be understood as the derivative of PCCx,x.


Introducing Fx,x into (13), we now have a direct relation between the output of the loop Δ[n] and the intersignal delay D that was previously implicit in FM1,M2:












F


M
1

,

M
2





[
Δ
]






PCC

x
,
x




[

Δ
-
D

]


-


PCC

x
,
x




[

Δ
-
D
-

τ
fix


]




=


F

x
,
x




[

Δ
-
D

]






(
15
)







Using (16), the delay-domain model in FIG. 8 can be obtained. This model can be used as a tool for the extraction of the system's transient and steady-state response, and also to determine the boundaries for the correct functioning of the loop. The low number of elements in the model and the first-order negative-feedback architecture create a misleading impression that the PCC-ATDE will follow a conventional analysis. The non-linear, x(t)-dependent function Fx,x is a complex mathematical element that affects all the parameters of the system, from the range of converter to the settling time and bandwidth.


In order to maintain the negative feedback and guarantee the convergence to the correct time-delay estimation, Fx,x[Δ−D] has to have positive values for Δ>D and negative values for Δ<D. Since Fx,x[Δ−D] is defined as the difference of two consecutive values of PCCx,x[τ], see (15), the equivalent condition is that the derivative of PCCx,x[τ] is positive for positive τ and negative for negative τ.



FIG. 9 shows the PCCx,x[τ] of band-limited noise signals in accordance with some embodiments. As illustrated, the local minima that limit the convergence condition for the PCC-ATDE, are indicated τMAX away from the peak of the PCCx,x[τ] at τ=0. Higher bandwidth analog input signals have their local minimum closer to the origin, and hence a have smaller τMAX.


To define a range for the system in some embodiments, the difference between Δ[n] and D must always be less than τMAX:





|Δ[n]−D|<τMAX   (17)


This can be an important design parameter for sound-source localization systems, where the maximum time delay between the input signals is limited by the spacing of the microphones. For example, if the microphones are separated by approximately 35cm, the intersignal delay will be always |D|<1 ms. Applying a boundary to the output |Δ|<1.5 ms will guarantee that the loop stays within the covered range for x(t) sources with bandwidth lower than 200 Hz that have a τMAX>2.5 ms. Low-pass filters can be used before the PCC-ATDE to limit the bandwidth of x(t) in some embodiments.



FIG. 10 illustrates an example of a CMOS embodiment of a time-discrete implementation of a PCC-ATDE TDE mechanism in accordance with some embodiments.


As shown, this mechanism can be implemented on a chip that has four analog inputs 1002, 1004, 1006, and 1008 that are connected to a microphone array. One of the microphones provides the reference for the time-delay estimation at input 1002; the chip outputs the time-delay of the other three analog signals with relation to this reference microphone.


The inputs are provided to inputs of comparators 1010. Any suitable comparators can be used in some embodiments. For example, in some embodiments, each comparator can be implemented as a latched comparator as shown in FIG. 11.


The outputs of the comparators are then provided to PCC-ATDE core 1012. The core can be implemented in any suitable technology. For example, in some embodiments, the core can be implemented in 0.18 μm CMOS technology to take advantage of its low leakage current, while easily meeting speed and density requirements. The core of the PCC-ATDE can be implemented with sub-threshold CMOS logic in some embodiments.


As shown in FIG. 10, the variable delay cells can be implemented with chains of 128 (or any other suitable number) flip-flops 1014 and 1016 and multiplexers 1018 and 1020. Any suitable flip-flops and multiplexers can be used in some embodiments. The delay can be controlled by selecting the output of one of the stages of a flip-flop chain using the corresponding multiplexer. After the 1-bit quantization, the multiplications are easily computed with XOR logic gates forming multipliers 1022 and 1024. An extra flip-flop 1026 (which can be any suitable flip-flop in some embodiments), placed after the upper multiplexer, provides the fixed delay τfix. A 10-bit register and adder can be used as an accumulator in some embodiments, and the 1/G attenuation can be realized with arithmetical shifts of 0, 1 or 2 bits. The output can be divided by two to evenly distribute, Δ[n], to both variable delay cells. In case of an odd Δ[n], one is added to the value of the lower variable delay cell.


In some embodiments, the 300 mV signals from the PCC-ATDE core can be converted to 1.8V I/O levels with the sub-threshold level shifters 1028. Any suitable level shifters can be used in some embodiments. For example, the level shifters shown in FIG. 12 can be used in some embodiments. In some embodiments, the level shifters are not required.


In some embodiments, the circuit of FIG. 10 can be used in an Internet of Things (IoT) embedded system for vehicle bearing estimation. The four microphones can be placed in a pyramid structure and connected to the circuit.


Although the invention has been described and illustrated in the foregoing illustrative embodiments, it is understood that the present disclosure has been made only by way of example, and that numerous changes in the details of implementation of the invention can be made without departing from the spirit and scope of the invention, which is limited only by the claims that follow. Features of the disclosed embodiments can be combined and rearranged in various ways.

Claims
  • 1. A circuit for a time-delay to digital converter, comprising: a first microphone having a first output;a second microphone having a second output;a first one-bit analog-to-digital converter having a first input coupled to the first output and having a third output;a second one-bit analog-to-digital converter having a second input coupled to the second output and having a fourth output;a first variable time delay having a third input coupled to the third output, a fourth input, and a fifth output, wherein the fourth input controls a delay amount of the first variable time delay;a second variable time delay having a fifth input coupled to the fourth output, a sixth input, and a sixth output, wherein the sixth input controls a delay amount of the second variable time delay;a first multiplier having a seventh input coupled to the fifth output, an eighth input coupled to the sixth output, and a seventh output;a third variable time delay having a ninth input coupled to the sixth output, and a eighth output;a second multiplier have a tenth input coupled to the fifth output, and eleventh input coupled to the eighth output, and a ninth output;a subtractor having a twelfth input coupled to the seventh output, a thirteenth input coupled to the ninth output, and a tenth output;an accumulator having a fourteenth input coupled to the tenth output, and an eleventh output;an attenuator having a fifteenth input coupled to the eleventh output, and a twelfth output;a differential splitter having a sixteenth input coupled to the twelfth output, a thirteenth output, and a fourteenth output;a first adder having a seventeenth input coupled to the thirteenth output, an eighteenth input coupled to an offset signal, and a fifteenth output coupled to the sixth input; anda second adder having a nineteenth input coupled to the fourteenth output, an twentieth input coupled to the offset signal, and a sixteenth output coupled to the fourth input.
CROSS-REFERENCE TO RELATED APPLICATION

The application claims the benefit of U.S. Provisional Patent Application No. 62/831,173, filed Apr. 8, 2019, and U.S. Provisional Patent Application No. 62/654,041, filed Apr. 6, 2018, each of which is hereby incorporated by reference herein in its entirety.

Provisional Applications (2)
Number Date Country
62831173 Apr 2019 US
62654041 Apr 2018 US