Next Article in Journal
Energy-Efficient Clustering and Routing Using ASFO and a Cross-Layer-Based Expedient Routing Protocol for Wireless Sensor Networks
Previous Article in Journal
Micromagnetic Study of the Dependence of Output Voltages and Magnetization Behaviors on Damping Constant, Frequency, and Wire Length for a Gigahertz Spin Rotation Sensor
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Calibration Methods for Time-to-Digital Converters †

ICube Research Institute, University of Strasbourg, CNRS, UMR 7357, 23 Rue du Loess, CEDEX, 67037 Strasbourg, France
*
Author to whom correspondence should be addressed.
This paper is an extended version of our paper published in High precision calibration method for asynchronous time-to-digital converters. In Proceedings of the 20th IEEE International NEWCAS Conference, Québec City, QC, Canada, 19–22 June 2022.
Sensors 2023, 23(5), 2791; https://doi.org/10.3390/s23052791
Submission received: 23 January 2023 / Revised: 13 February 2023 / Accepted: 28 February 2023 / Published: 3 March 2023
(This article belongs to the Section Physical Sensors)

Abstract

:
In this paper, two of the most common calibration methods of synchronous TDCs, which are the bin-by-bin calibration and the average-bin-width calibration, are first presented and compared. Then, an innovative new robust calibration method for asynchronous TDCs is proposed and evaluated. Simulation results showed that: (i) For a synchronous TDC, the bin-by-bin calibration, applied to a histogram, does not improve the TDC’s differential non-linearity (DNL); nevertheless, it improves its Integral Non-Linearity (INL), whereas the average-bin-width calibration significantly improves both the DNL and the INL. (ii) For an asynchronous TDC, the DNL can be improved up to 10 times by applying the bin–by-bin calibration, whereas the proposed method is almost independent of the non-linearity of the TDC and can improve the DNL up to 100 times. The simulation results were confirmed by experiments carried out using real TDCs implemented on a Cyclone V SoC-FPGA. For an asynchronous TDC, the proposed calibration method is 10 times better than the bin-by-bin method in terms of the DNL improvement.

1. Introduction

The role of a TDC is to measure precise time intervals between two events represented by two signals (reference and measured signals) [1,2,3,4], which is the keystone of many applications such as LIDAR applications [5], time-resolved fluorescence measurement [6], fluorescence lifetime imaging [7], 3-D active imaging and time-correlated photon counting [8]. In general, high-resolution TDCs can be built as Application-Specific Integrated Circuits (ASICs) [9]. However, for many applications, it can be better to implement the TDC on field-programmable gate arrays (FPGAs) due to the flexibility and reconfigurability, as well as the short development time of these circuits [10,11,12]. Moreover, the integration of hard processor systems in System-on-Chip FPGA (SoC-FPGA) kits allows performing an on-chip downstream processing such as a post-calibration process [11].
The Coarse–Fine architecture is extensively used to build FPGA-based TDCs to provide a high resolution and a large dynamic range [13,14,15]. The coarse TDC defines the TDC’s dynamic range; it is generally a classical counter clocked by the global system’s clock, whereas the fine TDC, which defines the resolution, is commonly based on the time interpolation technique [16]. The most common structure to build an FPGA-based fine TDC is the Tapped Delay Line (TDL) [14,17]. TDCs can be classified into two main categories: synchronous and asynchronous TDCs. In the synchronous TDC, the reference signal is synchronous with the system clock, and this type of TDCs consists of a coarse and a fine TDC. In contrast, in asynchronous TDCs, both the reference and the measured signals are asynchronous with the clock; thus, these TDCs include a coarse and two fine TDCs, for example, double-TDL. Generally, TDL-based TDCs implemented in FPGA suffer from a large non-linearity due to the large variations in the delay of the TDL cells [18]. This crucial drawback imposes calibrating the TDC to improve the linearity. The most prevailing calibration methods are the average-bin-width and the bin-by-bin methods [1,19,20]. In recent years, many studies have addressed these two methods, especially the bin-by-bin calibration. Nevertheless, most of these works have used this method for the calibration of individual time interval measurement, such as single-shot measurement and averaged measurement, without covering the calibration of histograms, which is an essential procedure for many TDC-based applications. In previous works [21,22,23], time measurement standard deviations of about 18 ps (0.4 LSB), 12.2 ps (1.07 LSB) and 9 ps (0.34 LSB) were achieved, respectively, through bin-by-bin calibration. However, these works did not apply this calibration method to histogram measurements. Furthermore, most of the studies about TDC calibration have predominantly focused on synchronous TDCs [24,25], and very few of them have discussed asynchronous TDCs. The aim of this paper is twofold: (i) to present the methodology and to compare the performance of the aforementioned methods when applied to histograms in the case of synchronous TDCs, and (ii) to propose an innovative robust calibration method for asynchronous TDCs named the “Matrix calibration”. This method, previously presented in [26], is performed as a post-processing of raw data for either ASIC- or FPGA-based TDCs. For its evaluation, this method is compared to the bin-by-bin method which is usually adopted for the calibration of asynchronous TDCs [27].
This paper starts with an introduction about Coarse–Fine TDCs. Section 2 covers the general functional principle of a Coarse–Fine synchronous TDC as well as its most used calibration methods. Section 3 firstly introduces the operating principal and calibration methods of asynchronous TDCs, then presents our proposed calibration method named the “Matrix calibration” in depth. The simulation and experimental results for the calibration of synchronous and asynchronous TDCs are, respectively, presented in Section 4 and Section 5. Lastly, Section 6 provides a brief conclusion of this work.

2. Synchronous TDCs Calibration

This section introduces the operating principle of synchronous TDCs. Then, it discusses the two reference methods of calibration of this type of TDCs, which are the bin-by-bin and the average-bin-width calibration methods.

2.1. Operating Principle of Synchronous TDCs

A TDC is an essential device for the measurement of precise time intervals between two events represented by two signals called “Start” and “Stop”. For synchronous Coarse–Fine TDCs, the Start signal is synchronized to the TDC system clock. Thus, the measured time interval Tm can be measured as a subtraction of two components: Tcoarse, which is the number of system clock cycles between the Start signal and the first clock’s rising edge after the Stop signal multiplied by the clock period, and Tfine, which is the interval from the Stop rising edge to the next clock rising edge, as illustrated in Equation (1) and Figure 1.
Tm = Tcoarse − Tfine
Hence, a synchronous Coarse–Fine TDC should contain two parts: a counter running at the system clock to measure Tcoarse and a fine block, which is usually a time interpolation structure, to measure Tfine.

2.2. Calibration Methods for Synchronous TDCs

The most popular calibration methods for synchronous TDCs are the bin-by-bin and the average-bin-width calibration methods. These methods require determining the raw bins’ widths by performing a code density test. The code density histogram integrates a sufficient number of counts in a way that the Stop signal arrives with random delays that cover the full range of the TDC. Thus, in the resulting histogram, each bin contains a number of counts proportional to its width. To illustrate the purpose, let us consider a five-bin TDC with a total delay of T. Figure 2 presents a code density histogram of this simple TDC. The mentioned methods are discussed as follows:

2.2.1. Bin-by-Bin Calibration

This method readdresses the TDC raw bins to calibrated times or calibrated bins by means of a lookup table (LUT). A code density test is performed to determine the time distribution along the fine TDC bins. Then, the calibrated time that corresponds to the center of the bin is calculated for each bin from Equation (2).
t i = [ N i 2 + k = 0 i 1 N k ] · T N
where ti is the calibrated time of bin i, N is the total number of counts in the code density histogram, T is the delay of the fine TDC and Ni is the number of counts in the ith bin. It has been shown in a previous study [28,29] that the RMS errors are minimized when the bins are calibrated to the centers. In fact, the RMS error σ of the bth bin, when calibrated to a time tc, can be calculated from (3).
σ 2 = 1 t max t min t min t max ( t t c ) 2   dt = ( t max t c ) 3 ( t min t c ) 3 3 ( t max t min )
where tmin and tmax are, respectively, the lower and upper time limits of this bin and tc is the calibrated time of this bin (tmin < tc < tmax).
Considering that tmin = 0 and tmax = Tb (Tb is the bin width), Equation (3) can be written as:
σ 2 = ( T b t c ) 3 + t 3 3 T b =   T b t c 2 T b 2 t c + T b 3 3
The minimum RMS error is obtained when t c = T b 2 = ( t max t min ) 2 , and the minimum RMS error is calculated from Equation (5).
σ 2 = ( t max t min ) 2 12
The calibrated times of the raw bins calculated from Equation (2) are stored in a bin-to-time LUT that will be used later for the correction of the TDC’s non-linearity. Furthermore, the FSR of the TDC can be divided into calibrated bins with identical size. The calibrated time of the raw bins are then projected on the calibrated bins to determine which raw bin corresponds to which calibrated bin, as illustrated in Figure 3a. Thereafter, another LUT, namely the bin-to-calibrated_bin LUT, can be built to be used for the calibration of the measurement histogram or to convert the raw bin into a calibrated one in real-time, as presented in Figure 3b.
Figure 3a demonstrates that there are still large variations in the width of the calibrated bins. In this example, the third calibrated bin (C_Bin3) is a dead bin because the TDC has a large raw bin (Bin2). In addition, both the small raw bins (Bin3 and Bin4) are included in one corrected bin (C_Bin4).

2.2.2. Average-Bin-Width Calibration Method

This method aims to divide the fine TDC into calibrated bins with identical widths. As for the bin-by-bin calibration, this method requires performing a code density. From this test, the delay of the time width of the bth raw bin (Tb) can be calculated from Equation (6), where N is the number of counts of the code density histogram, Nb is the number of counts in the bth bin and T is the fine TDC’s delay:
T b = N b N
The idea of this calibration is to divide the fine TDC into M calibrated bins with identical time widths Tc. Since T is the total delay of the fine TDC, Tc is calculated from Equation (7).
T c = T M
Furthermore, since the calibrated bins have a uniform time width, these bins should contain the same number of counts Nc, calculated from Equation (8), when performing a code density test:
N c = N M
Considering the code density histogram presented in Figure 2 that has five non-identical raw bins, in order to have five calibrated bins identical in size, the counts of the raw bins are successively redistributed on the calibrated bins starting from the first bin. For each calibrated bin, the percentage shares of the raw bins are calculated as demonstrated in Figure 4 and stored in a special table, named the calibration table, as presented in Figure 5. This table will be used later for the calibration of the measurement raw histogram.
Figure 4 illustrates that the calibrated histogram using this method has calibrated bins with identical size. This histogram has no dead bins because the large raw bin (Bin2) is distributed to four corrected bins (C_Bin1, C_Bin2, C_Bin3 and C_Bin4) with different percentages. It can also be noticed that the fourth corrected bin (C_Bin4) contains counts from four different raw bins (C_Bin2, C_Bin3, C_Bin4 and C_Bin5) also at different percentages.
Moreover, the TDC time resolution depends on the calibrated bin size; in other words, it depends on the number of calibrated bins. If the number of calibrated bins is L, the time resolution of the TDC after the calibration is calculated by Equation (9).
T c = T L

3. Asynchronous TDCs Calibration

This section first explains the functionality of asynchronous TDCs as well as the bin-by-bin calibration for such TDCs. Then, it presents in detail our proposed methodology to calibrate asynchronous TDCs.

3.1. Operating Principle of Asynchronous TDCs

In asynchronous TDCs, the Start signal is asynchronous with respect to the TDC clock, as is the Stop signal. Therefore, the time interval between these signals, Tm, is calculated using the following equations, as illustrated in Figure 6:
Tm = Tcoarse + Tfine1 − Tfine2
Tm = Coarse × Tclk + Tfine1 − Tfine2
where Tfine1 is the interval between the Start signal and the first rising edge of the clock that arrives after the Start signal, Tfine2 is the interval between the Stop signal and the first rising edge of the clock after the Stop signal and Tcoarse is the number of clock cycles between the mentioned clock rising edges multiplied by the clock period.
Hence, an asynchronous Coarse–Fine TDC should contain a coarse counter that measures Tcoarse and two fine TDCs: one for the measurement of Tfine1 called the Start fine TDC, and another one that measures Tfine2 named the Stop fine TDC.
It is evident from Equation (11) that, in asynchronous TDCs, each count can be represented by three values: Start fine bin number (fine1), Stop fine bin number (fine2) and the coarse counter value (coarse). Therefore, the measured counts can be compiled in a 3-D histogram. Again, to illustrate the purpose, let us consider a 3-D asynchronous TDC with five bins for the Start and Stop fine TDCs and a clock period T. Figure 7 illustrates a 3-D code density histogram of such a TDC.

3.2. Calibration Methods for Asynchronous TDCs

3.2.1. Bin-by-Bin Method

To calibrate an asynchronous TDC using the bin-by-bin method, firstly, a code density test is performed to calculate the calibrated times of the raw bins and build the lookup tables of the two fine TDCs, as explained for synchronous TDCs in II-B-1. Figure 8 shows the built LUTs.
Thereafter, the calibrated interval of each cell of the 3-D histogram can be calculated, using the lookup tables built in the previous step, from the following equation:
t_cell = (Coarse × T) + t_start − t_stop
where t_cell is the calibrated time of the cell, t_stop, t_start are the calibrated times of the Stop and Start bins that represent the (x, y) coordinates of the cell, T is the system clock period and Coarse is the cell coarse value.
The calibrated intervals of all the cells are then saved in a 3-D LUT that can be used for the correction of the TDC’s non-linearity. Furthermore, the FSR of the TDC can be divided into calibrated bins with identical size to determine to which calibrated bin, in the final calibrated 1-D histogram, corresponds each cell of the 3-D raw histogram, according to its calibrated interval. Finally, a cell-to-calibrated_bin 3-D LUT can be built to be used later for the calibration of the measurement to convert its 3-D raw histogram to a 1-D calibrated one.

3.2.2. Matrix Calibration

Matrix calibration is based on the average-bin-width method and used for the calibration of asynchronous Coarse–Fine TDCs. It requires performing a code density test with a sufficient number of counts for which the Start and the Stop signals arrive at different delays, asynchronously to the system clock, in a way that they cover the FSR of the Start and Stop fine TDCs. Considering the 3-D code density histogram, illustrated in Figure 7, each cell stores the number of counts for which the Start and Stop signals arrive in the bins that respectively correspond to the x and y coordinates of this cell and with a coarse value equal to its z coordinate. For instance, the cell (4, 3, 1) saves the number of counts in which the Start signal arrives in the fourth bin of the Start fine TDC, and the Stop signal arrives in the third bin and with a coarse value equal to 1. In the case of ideal Start and Stop fine TDCs with identical raw bins, all the cells of the code density histogram would have an identical size. In a real TDC, since the fine TDCs have non-uniform raw bins, the cells of the 3-D code density histogram have different sizes. The size of each cell, represented by its number of counts, depends on the width of its Start and Stop raw bins.
One way to calibrate the 3-D code density histogram is to make all the cells have a uniform size. The matrix calibration consists in redistributing the code density counts evenly on calibrated cells identical in size. This can be achieved in four steps:
1.
Step 1: Individual calibration of the Start and Stop fine.
In fact, if the Stop fine and the coarse values of the 3-D code density histogram cells are ignored, the columns will be merged in one column. This column is a 1-D histogram that represents a code density histogram of the Start fine TDC. Likewise, merging all the rows, by ignoring the Start fine and the coarse values, provides a 1-D code density histogram of the Stop fine TDC. These histograms can be used to build the calibration table of the Start and Stop fine TDCs, as described in II-B-2 for the average-bin-calibration of synchronous TDCs. Figure 9 shows the built calibration tables.
2.
Step 2: Column calibration.
In practice, each column of the 3-D code density histogram can be considered a 1-D code density histogram of the Start fine TDC, and thus can be calibrated using the Start calibration table built in the previous step. The individual calibration of all the columns of the 3-D histogram results in a semi-calibrated 3-D histogram in which all the cells have the same row height while the columns still have non-uniform widths, as illustrated in Figure 10.
3.
Step 3: Row calibration.
The rows of the semi-calibrated histogram resulting from the previous step are practically 1-D code density histograms of the Stop fine TDC. Hence, they can be calibrated using the calibration table of this TDC. The individual calibration of all the rows provides the calibrated 3-D histogram where all the cells have identical size, as shown in Figure 11.
4.
Step 4: Building 1-D calibrated histogram.
The last step of the matrix calibration aims to convert the 3-D histogram resulted from the previous step into a 1-D histogram. In fact, each cell of the 3-D calibrated histogram should be added to its corresponding bin in the 1-D calibrated histogram. The number of this bin is calculated by Equation (13).
Bin_number = (Coarse × M) + C_fine1 − C_fine2
where C_fine1, C_fine2, Coarse are, respectively, the x, y, z coordinates of the calibrated cell, i.e., the numbers of its row, column and slice, and M is the total number of calibrated bins in the Stop fine TDC, which equals 5 in our example. For instance, the counts of the cell (3, 2, 4) is part of the 21st bin of the calibrated 1-D histogram, since M = 5 and, thus, the number of the bin to which corresponds this cell is ((4 × 5) + 3 − 2 = 21).
Consequently, in this step, all the cells of the 3-D calibrated histogram should be scanned and added to their corresponding bins in the 1-D calibrated histogram.

4. Simulation Results

Different simulations were carried out using MATLAB to compare the studied calibration methods for synchronous and asynchronous TDCs. The simulated TDCs are based on the Nutt method and consist of fine and coarse TDCs. The coarse TDC is a simple counter and the fine TDC is a TDL with 256 delay elements. The total delay of the TDL is 5 ns distributed on the delay elements with the same profile of the time distribution along a real TDL implemented on a Cyclone V FPGA [11].

4.1. Synchronous TDCs

In the first simulation, 10 synchronous TDCs were simulated with different Root Mean Square (RMS) differential non-linearity (DNL) that varied from 0 to 1 LSB. For each simulated TDC, 107 random events were simulated to perform a code density. The Stop signal for these events arrived with random delays uniformly distributed over the total delay of the TDC’s TDL. The resulting code density histogram was used to build the calibration tables of the average-bin-width calibration and the LUTs of the bin-by-bin method. Thereafter, for the evaluation and comparison of these two methods, another code density test, was performed with another 107 simulated random events. Then, the two methods were applied to calibrate the resulting code density histogram. After repeating these steps for each of the 10 simulated TDCs, the RMS DNL of the calibrated histograms was calculated to evaluate the calibration method. Figure 12 illustrates the obtained results and shows that the bin-by-bin method did not improve the DNL of the TDC, whereas the average-bin-width calibration was independent to the noise of the TDC and significantly improved the DNL.
It should be pointed out that since the DNL of the first TDC in this simulation was 0 LSB, i.e., an ideal TDC, the DNL after applying the calibration should theoretically be 0 LSB. Nevertheless, the calibrated histogram had a DNL of about 0.005 LSB. This is because code density tests are limited by the shot noise, which can be calculated from Equation (14).
Shot   noise = Number   of   Bins Counts   number
In our case, the number of bins was 256 and the counts number was 107, and this equation gives about 0.005 LSB.
The second simulation aimed to compare the DNL and the integral non-linearity (INL) of the two calibration methods when applied to a simulated TDC that has the same time distribution as a real one implemented on a Cyclone V SoC-FPGA [11]. As for the first simulation, two code density tests, with 107 events each, were simulated. The first test was to build the bin-by-bin LUT and the average-bin-width calibration table. The second test was to apply the two calibration methods and to compare between them. Figure 13 presents the DNL and INL values of the calibrated histograms obtained after applying the two methods as well as those of the non-calibrated histogram, and Table 1 summarizes the data statistics of these values. The obtained results show that the bin-by-bin calibration improved just the INL of the TDC without improving its DNL, whereas the average-bin-width calibration significantly improved both the DNL and the INL.
The third simulation demonstrates the advantage of the average-bin-width over the bin-by-bin calibration applied to histograms. In this simulation, a Gaussian signal was measured by a simulated TDC that had the time distribution of the real TDC, as in the previous simulation. Ten million (107) events were simulated following a normal distribution with an arbitrary chosen average delay of 2.5 ns and standard deviation (sigma) of 0.3 ns. The two calibration methods were then applied to calibrate the recorded histogram. Figure 14 shows the resulting calibrated histograms of the Gaussian signal. It is evident that the average-bin-width calibration had much less noise than the bin-by-bin method.

4.2. Asynchronous TDCs

In the first simulation, 10 asynchronous TDCs were simulated with RMS DNL values that varied between 0 LSB and 1 LSB. These DNL values were measured after concatenating the raw bins of the two fine TDCs of each asynchronous TDC. Thereafter, for each simulated TDC, a code density test was simulated with 107 random events to build the bin-by-bin LUTs and the calibration tables of the matrix calibration. Then, for the evaluation and the comparison between the two methods, another code density test was simulated with 107 events. For these events, the Start signal arrived with random delays uniformly distributed over the range of the Start fine TDC, and the Stop signal arrived after the Start signal by time intervals that varied uniformly from 0 to 5 ns. From the arrival times of these events, a 3-D raw histogram was built by calculating the coordinates of each event, i.e., its Start fine bin, Stop fine bin and coarse value, and incrementing the corresponding cell by one. Thereafter, the bin-by-bin and the matrix calibration methods were applied to calibrate the 3-D raw histograms and deduce 1-D calibrated histograms. The RMS DNL values of these calibrated histograms were measured to compare the calibration methods, and the results are presented in Figure 15.
The results illustrated in Figure 15 show that the DNL values of the calibrated histograms obtained by the bin-by-bin method were improved by a factor of 10 and linearly increased with the DNL of the TDC. In contrast, the proposed matrix calibration method was much less sensitive to the noise of the raw TDC with an almost flat response. The error of the ideal TDC (noise 0 LSB) is also due to the shot noise, as discussed for the synchronous TDC, and can be calculated by Equation (14) and equals 0.005 LSB.
In the next simulation, an asynchronous TDC was simulated with 256-delay-element Start and Stop fine TDCs that had the same time distribution as an asynchronous TDC implemented on a Cyclone V FPGA [11]. Firstly, a code density test was simulated to build the LUTs and the calibration tables in the same way as in the previous simulation. Then, the bin-by-bin and the matrix calibration methods were applied to calibrate the raw histogram of another simulated code density test. Thereafter, for the evaluation of these two methods, the obtained calibrated histograms were compared with the non-calibrated one in terms of the DNL and INL values.
Figure 16 shows the DNL and INL values after applying the calibration methods as well as those of the non-calibrated histogram. Table 2 summarizes the data statistics of these values.
The obtained results show that the bin-by-bin method improved the INL, compared with the non-calibrated histogram, without improving the DNL. However, the matrix calibration is more than 10 times better than the bin-by-bin method in terms of the DNL and about 2 times better in terms of the INL. Nevertheless, comparing these results with those obtained for a synchronous TDC, presented above in Figure 13 and Table 1, it can be noticed that the DNL and INL of the non-calibrated histogram of an asynchronous TDC are about 10 times less accurate than their values for a synchronous TDC.
The last simulation compared the two methods applying each to a calibrated measurement histogram of Gaussian signal. Using the simulated TDC of the previous simulation, a Gaussian signal was simulated by 107 events. The time interval between the Start and Stop signals of these events followed a normal distribution with arbitrary chosen average delay and standard deviation of 2.5 ns and 0.5 ns, respectively. The obtained results depicted in Figure 17 show that the average-bin-width calibration had less noise than the bin-by-bin method. Furthermore, the center of gravity of the calibrated histogram was 2489.5 ps (error = 10.5 ps) for the bin-by-bin method, whereas it was 2499.1 ps (error = 0.9 ps) for the matrix calibration.

5. Experimental Results

In this section, experiments were performed on real TDCs, implemented on a Cyclone V FPGA, to confirm the simulation results for synchronous and asynchronous TDCs.

5.1. Synchronous TDCs

In this experiment, a synchronous TDC was implemented on the FPGA kit. The coarse TDC was an 8-bit counter and the fine TDC was a Tapped Delay Line (TDL) of 256 delay elements. The system clock period was 5 ns, i.e., the fine TDC range was 5 ns. The Start signal was synchronized with the system clock, whereas the Stop signal was connected to the output signal of a Single-Photon Avalanche Diode (SPAD) to build the LUT and the calibration table of the bin-by-bin and the average-bin-width calibration methods, respectively. A code density test with about 107 events was performed by exposing the SPAD to the ambient light at a low detected photon rate of about 1 M photon/s. At such a relatively low photon rate, the mean time between the arrival of two successive photons is 1 µs, which is 200 times larger than the total delay of the fine TDC. Thus, the Stop signal arrived with random delays that covered the FSR of the TDC. From the code density histogram, the RMS DNL of the raw TDC was calculated and it was about 0.69 LSB. Thereafter, another code density test was performed with the same number of events to evaluate the calibration methods. The code density histogram was then calibrated using the two methods and the RMS DNL was calculated for the resulting calibrated histograms. For the bin-by-bin method, the RMS DNL was 0.74 LSB, whereas it was just 0.017 LSB for the average-bin-width method. These experimental values confirm the simulation results, as plotted in Figure 12.
Moreover, the implemented system was used in real conditions to record the fluorescence signal of a piece of paper excited by a 405 nm laser pulse [30]. Figure 18 shows the calibrated histogram of the recorded signal using the two calibration methods. It confirms that the average-bin-width calibration had much less noise than the bin-by-bin method.

5.2. Asynchronous TDCs

To experimentally verify our proposed method “the Matrix Calibration” and to confirm the simulation results, an asynchronous TDC was implemented on the FPGA kit. This TDC consisted of an 8-bit coarse counter, clocked at a system clock frequency of 200 MHz, and two TDL-based fine TDCs with 256 delay elements each. In addition, a separate on-chip PLL generated an asynchronous Start signal, whereas the Stop signal was connected to the output signal of a SPAD. Firstly, a code density test was performed by exposing the SPAD to the ambient light at a low detected photon rate of 1 M photon/s. Therefore, the arrival time of the Start and Stop signals of the measured events can be considered uniformly distributed over the range of the fine TDCs. From the code density histogram, the 3-D LUT and the calibration tables were built for the bin-by-bin and the matrix calibration, and the RMS DNL of the fine TDCs was calculated (0.71 LSB). Thereafter, another code density test was performed and the resulting histogram was calibrated by the two calibration methods. The RMS DNL of the resulting calibrated histograms were calculated and the results are as following: (0.053 LSB) for the bin-by-bin method and only (0.005 LSB) for the matrix calibration, as plotted on Figure 15. Indeed, in order to have experimental results comparable with the simulation, the same number of events must be measured in the experimental code density tests as in simulation, i.e., 107 events.
As for the synchronous TDC, in the last experiment, the implemented asynchronous TDC was used in real conditions to record the fluorescence signal of a piece of paper. Figure 19 shows the calibrated histogram of the recorded signal obtained after applying the bin-by-bin and the matrix calibration methods. This figure shows that the matrix calibration had less noise than the average-bin-width method. Nevertheless, the bin-by-bin calibration, when applied to asynchronous TDCs, has much less noise than when it is applied to synchronous ones.

5.3. Processing Speed Comparison

The average-bin-width and the matrix calibration methods lead to better results in terms of noise than the bin-by-bin method. The drawback is a more complex signal processing which includes more multiplications and data access. As mentioned before, the average-bin-width calibration and the matrix calibration are post-processing on the TDC raw data. Moreover, the bin-by-bin method for asynchronous TDCs is very complicated to implement for online calibration, and it is easier to be performed as post-processing. Thus, all the studied calibration methods were implemented as post-processing. The SoC-FPGA kit used in experiments integrates a hard processor system (HPS), namely the ARM Cortex A9 processor, with a Cyclone V FPGA fabric and provides a high-speed interface for the data transfer between these two parts. The TDC systems were implemented on the FPGA and the data were transferred into the SDRAM of the HPS to be processed by performing the different calibration techniques and other data processing. A set of experiments were carried out to compare the speed of the different calibration methods on the implemented TDCs, knowing that the number of raw bins in a fine TDC is 256 bins.
Table 3 compares the processing time between the bin-by-bin calibration for asynchronous TDCs and the matrix calibration. It compares the time of applying the calibration without considering the time of creating the LUTs and the calibration tables. This table shows that the speed of the bin-by-bin calibration depends only on the maximum value of Coarse (Coarse_max), because the size of the 3-D LUT is always equal to (the number of raw bins in Start fine TDC × number of raw bins in Stop fine TDC × Coarse_max), as illustrated in Figure 7, whereas the matrix calibration speed depends on the total number of calibrated bins in the histogram, as shown in Figure 5. Furthermore, the ratio between the speed of the two methods has almost a linear relationship with the number of calibrated bins in the clock period; this ratio has a maximum value of about 8 when the number of calibrated bins in a period is equal to the number of raw bins.
The same experiments were performed on a synchronous TDC. The obtained results show that the ratio between the speed of the average-bin-width has an almost linear relationship with the number of calibrated bins in clock period; the maximum value of this ratio is about 4 when the number of calibrated bins in a clock period is equal to the number of raw bins of the fine TDC.

6. Conclusions

This paper covers in detail the methodology of the most commonly used calibration methods for synchronous and asynchronous TDCs, which are the bin-by-bin and average-bin-width methods. It also introduces a novel calibration method for asynchronous TDCs called the “Matrix calibration”. Simulations and experiments were carried out to compare these methods. The results show that, for synchronous TDCs, the average-bin-width calibration is much better than the bin-by-bin method, which does not improve the DNL of the raw TDC. The obtained results also affirm that the proposed method for asynchronous TDCs is less sensitive to the DNL of the raw TDC and is up to 10 times better than the bin-by-bin method applied for histogram measurements. This improvement occurs at the expense of a longer calibration time due to the complexity of the signal processing that includes more multiplication and memory access instructions. Furthermore, experimental results obtained for real TDCs, implemented on Cyclone V FPGA, confirmed the simulation results. However, it should be pointed out that the proposed calibration method does not improve the TDC precision in the case of single-shot measurements.
The proposed method has been effectively applied in a Time-Correlated Single Photon Counting (TCSPC) system including asynchronous TDCs. Another paper about this system will be published in the future. Furthermore, this method can be extended to be applied for the calibration of other systems dealing with multidimensional histograms involving more than three dimensions.

Author Contributions

Conceptualization, W.K. and W.U.; methodology, W.K. and W.U.; software, W.K., F.D. and N.D.; validation, W.K., W.U., M.M., N.D. and F.D.; formal analysis, W.K.; investigation, W.K., W.U., M.M., N.D. and F.D.; writing—original draft preparation, W.K.; writing—review and editing, W.K., W.U., M.M., N.D. and F.D.; supervision, W.U. and M.M.; project administration, W.U. and M.M.; funding acquisition, W.U. and M.M. All authors have read and agreed to the published version of the manuscript.

Funding

This research was funded in part by the French National Research Agency (Agence Nationale de la Recherche ANR), grant number ANR-15-CE11-0006 (PICO2), in part by the European Regional Development Fund (ERDF) and in part by the Interreg V Upper Rhine Offensive Sciences Program (Project 3.14—water pollution sensor).

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

Not applicable.

Acknowledgments

The authors would like to thank the French National Research Agency (ANR-15-CE11-0006), the European Regional Development Fund (ERDF) and the Interreg V Upper Rhine Offensive Sciences Program for funding this study.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Choi, K.-J.; Jee, D.-W. Design and Calibration Techniques for a Multichannel FPGA-Based Time-to-Digital Converter in an Object Positioning System. IEEE Trans. Instrum. Meas. 2021, 70, 1–9. [Google Scholar] [CrossRef]
  2. Qin, X.; Zhu, M.; Zhang, W.; Lin, Y.; Rui, Y.; Rong, X.; Du, J. A high resolution time-to-digital-convertor based on a carry-chain and DSP48E1 adders in a 28-nm field-programmable-gate-array. Rev. Sci. Instrum. 2020, 91, 024708. [Google Scholar] [CrossRef] [Green Version]
  3. Won, J.Y.; Kwon, S.I.; Yoon, H.S.; Ko, G.B.; Son, J.-W.; Lee, J.S. Dual-Phase Tapped-Delay-Line Time-to-Digital Converter with On-the-Fly Calibration Implemented in 40 nm FPGA. IEEE Trans. Biomed. Circuits Syst. 2016, 10, 231–242. [Google Scholar] [CrossRef]
  4. Chen, H.; Zhang, Y.; Li, D.D.-U. A Low Nonlinearity, Missing-Code Free Time-to-Digital Converter Based on 28-nm FPGAs with Embedded Bin-Width Calibrations. IEEE Trans. Instrum. Meas. 2017, 66, 1912–1921. [Google Scholar] [CrossRef] [Green Version]
  5. Incoronato, A.; Locatelli, M.; Zappa, F. Statistical Modelling of SPADs for Time-of-Flight LiDAR. Sensors 2021, 21, 4481. [Google Scholar] [CrossRef] [PubMed]
  6. Dieguez, A.; Canals, J.; Franch, N.; Dieguez, J.; Alonso, O.; Vila, A. A Compact Analog Histogramming SPAD-Based CMOS Chip for Time-Resolved Fluorescence. IEEE Trans. Biomed. Circuits Syst. 2019, 13, 343–351. [Google Scholar] [CrossRef]
  7. Nie, K.; Wang, X.; Qiao, J.; Xu, J. A Full Parallel Event Driven Readout Technique for Area Array SPAD FLIM Image Sensors. Sensors 2016, 16, 160. [Google Scholar] [CrossRef] [Green Version]
  8. Villa, F.; Markovic, B.; Bellisai, S.; Bronzi, D.; Tosi, A.; Zappa, F.; Tisa, S.; Durini, D.; Weyers, S.; Paschen, U.; et al. SPAD Smart Pixel for Time-of-Flight and Time-Correlated Single-Photon Counting Measurements. IEEE Photonics J. 2012, 4, 795–804. [Google Scholar] [CrossRef]
  9. Huang, Z.; Huang, J.; Tian, L.; Wang, N.; Zhu, Y.; Wang, H.; Feng, S. A 13-Bit, 12-ps Resolution Vernier Time-to-Digital Converter Based on Dual Delay-Rings for SPAD Image Sensor. Sensors 2021, 21, 743. [Google Scholar] [CrossRef]
  10. Wang, J.; Liu, S.; Shen, Q.; Li, H.; An, Q. A Fully Fledged TDC Implemented in Field-Programmable Gate Arrays. IEEE Trans. Nucl. Sci. 2010, 57, 446–450. [Google Scholar] [CrossRef]
  11. Khaddour, W.; Dadouche, F.; Uhring, W.; Frick, V.; Madec, M. Design Methodology and Timing Considerations for implementing a TDC on a Cyclone V FPGA Target. In Proceedings of the 2020 18th IEEE International New Circuits and Systems Conference (NEWCAS), Montreal, QC, Canada, 16–19 June 2020; pp. 126–129. [Google Scholar]
  12. Dadouche, F.; Turko, T.; Malass, I.; Skilitsi, A.; Léonard, J.; Uhring, W. Design, Implementation and Characterization of Time-to-Digital Converter on Low-Cost FPGA. In Sensors and Applications in Measuring and Automation Control Systems; Sergey, Y., Yurish, Eds.; Book Series: Advances in Sensors: Reviews; Sensors and Applications in Measuring and Automation Control Systems; International Frequency Sensor Association (IFSA): Barcelona, Spain, 2016; Volume 4, pp. 205–229. [Google Scholar]
  13. Garzetti, F.; Corna, N.; Lusardi, N.; Geraci, A. Time-to-digital converter IP-core for FPGA at state of the art. IEEE Access 2021, 9, 85515–85528. [Google Scholar] [CrossRef]
  14. Parsakordasiabi, M.; Vornicu, I.; Rodríguez-Vázquez, Á.; Carmona-Galán, R. A Low-Resources TDC for Multi-Channel Direct ToF Readout Based on a 28-nm FPGA. Sensors 2021, 21, 308. [Google Scholar] [CrossRef] [PubMed]
  15. Li, D.; Ma, R.; Wang, X.; Hu, J.; Liu, M.; Zhu, Z. DTOF Image LiDAR with Stray Light Suppression and Equivalent Sampling Technology. IEEE Sens. J. 2022, 22, 2358–2369. [Google Scholar] [CrossRef]
  16. Bayer, E.; Traxler, M. A High-Resolution (<10 ps RMS) 48-Channel Time-to-Digital Converter (TDC) Implemented in a Field Programmable Gate Array (FPGA). IEEE Trans. Nucl. Sci. 2010, 58, 1547–1552. [Google Scholar]
  17. Zhang, M.; Zhao, Y.; Han, Z.; Zhao, F. A 19 ps Precision and 170 M Samples/s Time-to-Digital Converter Implemented in FPGA with Online Calibration. Appl. Sci. 2022, 12, 3649. [Google Scholar] [CrossRef]
  18. Chen, Y. Run-time calibration scheme for the implementation of a robust field-programmable gate array-based time-to-digital converter. Int. J. Circuit Theory Appl. 2018, 47, 19–31. [Google Scholar] [CrossRef] [Green Version]
  19. Xu, Y.; Xie, J.; Xing, Z.; Yuan, W.; Yu, G.; Zeng, Z.; Zhang, B.; Wu, D. A Bin-by-Bin Calibration with Neural Network for FPGA-Based Tapped-Delay-Line Time-to-Digital Converter. In Proceedings of the 2022 IEEE International Conference on Real-Time Computing and Robotics (RCAR), Guiyang, China, 17–22 July 2022; pp. 681–686. [Google Scholar]
  20. Song, Z.; Zhao, Z.; Yu, H.; Yang, J.; Zhang, X.; Sui, T.; Xu, J.; Xie, S.; Huang, Q.; Peng, Q. An 8.8 ps RMS Resolution Time-To-Digital Converter Implemented in a 60 nm FPGA with Real-Time Temperature Correction. Sensors 2020, 20, 2172. [Google Scholar] [CrossRef] [Green Version]
  21. Cao, G.; Xia, H.; Dong, N. An 18-ps TDC using timing adjustment and bin realignment methods in a Cyclone-IV FPGA. Rev. Sci. Instrum. 2018, 89, 054707. [Google Scholar] [CrossRef]
  22. Mao, X.; Yang, F.; Wei, F.; Shi, J.; Cai, J.; Cai, H. A Low Temperature Coefficient Time-to-Digital Converter with 1.3 ps Resolution Implemented in a 28 nm FPGA. Sensors 2022, 22, 2306. [Google Scholar] [CrossRef]
  23. Zhang, W.; Edwards, C.; Gong, D.; Huang, X.; Liu, C.; Liu, T.; Liu, T.; Olsen, J.; Sun, H.; Sun, Q.; et al. TDC with uncontrolled delay lines: Calibration approaches and Precision Improvement Methods. J. Instrum. 2023, 18, C01011. [Google Scholar] [CrossRef]
  24. Ito, S.; Nishimura, S.; Kobayashi, H.; Uemori, S.; Tan, Y.; Takai, N.; Yamaguchi, T.J.; Niitsu, K. Stochastic TDC architecture with self-calibration. In Proceedings of the 2010 IEEE Asia Pacific Conference on Circuits and Systems, Kuala Lumpur, Malaysia, 6–9 December 2010; pp. 1027–1030. [Google Scholar]
  25. Yao, C.-W.; Ni, R.; Lau, C.; Wu, W.; Godbole, K.; Zuo, Y.; Ko, S.; Kim, N.-S.; Han, S.; Jo, I.; et al. A 14-nm 0.14-ps rms Fractional-N Digital PLL with a 0.2-ps Resolution ADC-Assisted Coarse/Fine-Conversion Chopping TDC and TDC Nonlinearity Calibration. IEEE J. Solid-State Circuits 2017, 52, 3446–3457. [Google Scholar] [CrossRef]
  26. Khaddour, W.; Uhring, W.; Dadouche, F.; Dumas, N.; Madec, M. High precision calibration method for asynchronous time-to-digital converters. In Proceedings of the 2022 20th IEEE Interregional NEWCAS Conference (NEWCAS), Québec City, QC, Canada, 19–22 June 2022; pp. 421–425. [Google Scholar]
  27. Pan, W.; Gong, G.; Li, J. A 20-ps Time-to-Digital Converter (TDC) Implemented in Field-Programmable Gate Array (FPGA) with Automatic Temperature Correction. IEEE Trans. Nucl. Sci. 2014, 61, 1468–1473. [Google Scholar] [CrossRef]
  28. Wu, J. Several key issues on implementing delay line based TDCs using FPGAs. IEEE Trans. Nucl. Sci. 2010, 57, 1543–1548. [Google Scholar] [CrossRef]
  29. Wu, J. Uneven bin width digitization and a timing calibration method using cascaded PLL. In Proceedings of the 19th IEEE-NPSS Real Time Conference, Nara, Japan, 26–30 May 2014. [Google Scholar]
  30. Uhring, W.; Zint, C.-V.; Bartringer, J. A low-cost high-repetition-rate picosecond laser diode pulse generator. In Proceedings of the Semiconductor Lasers and Laser Dynamics, Strasbourg, France, 26–30 April 2004; Volume 5452, pp. 583–590. [Google Scholar]
Figure 1. Synchronous Coarse–Fine TDC principle. Tm can be measured as a subtraction of two components, Tcoarse and Tfine.
Figure 1. Synchronous Coarse–Fine TDC principle. Tm can be measured as a subtraction of two components, Tcoarse and Tfine.
Sensors 23 02791 g001
Figure 2. Code density histogram of a simple synchronous TDC with five bins.
Figure 2. Code density histogram of a simple synchronous TDC with five bins.
Sensors 23 02791 g002
Figure 3. Bin-by-bin calibration: (a) Calculating the calibrated times and calibrated bins of the raw bins; (b) Bin-by-bin calibration lookup table.
Figure 3. Bin-by-bin calibration: (a) Calculating the calibrated times and calibrated bins of the raw bins; (b) Bin-by-bin calibration lookup table.
Sensors 23 02791 g003
Figure 4. Average-bin-width calibration, redistribution of the total counts on identical calibrated bins and creating the calibration table that defines the percentage share of raw bins in each calibrated one.
Figure 4. Average-bin-width calibration, redistribution of the total counts on identical calibrated bins and creating the calibration table that defines the percentage share of raw bins in each calibrated one.
Sensors 23 02791 g004
Figure 5. Calibration table of the fine TDC. It describes the shares of the raw bins in the calibrated bins.
Figure 5. Calibration table of the fine TDC. It describes the shares of the raw bins in the calibrated bins.
Sensors 23 02791 g005
Figure 6. Asynchronous TDC chronogram. The time interval between two asynchronous signals to the system clock is calculated from three parts: two fine intervals and a coarse one.
Figure 6. Asynchronous TDC chronogram. The time interval between two asynchronous signals to the system clock is calculated from three parts: two fine intervals and a coarse one.
Sensors 23 02791 g006
Figure 7. Three-dimension code density histogram of an asynchronous TDC with five-bin fine TDCs, the Stop and Start fine bin numbers are respectively represented on x and y, whereas the Coarse value is represented on z.
Figure 7. Three-dimension code density histogram of an asynchronous TDC with five-bin fine TDCs, the Stop and Start fine bin numbers are respectively represented on x and y, whereas the Coarse value is represented on z.
Sensors 23 02791 g007
Figure 8. Lookup tables of the two fine TDCs: (a) Start fine TDC LUT; (b) Stop fine TDL LUT.
Figure 8. Lookup tables of the two fine TDCs: (a) Start fine TDC LUT; (b) Stop fine TDL LUT.
Sensors 23 02791 g008
Figure 9. Individual calibration tables: (a) Start fine TDC calibration table; (b) Stop fine TDC calibration table.
Figure 9. Individual calibration tables: (a) Start fine TDC calibration table; (b) Stop fine TDC calibration table.
Sensors 23 02791 g009
Figure 10. Column calibration, the individual calibration of the columns using the average-bin-width method gives a semi-calibrated histogram where all the rows have the same height.
Figure 10. Column calibration, the individual calibration of the columns using the average-bin-width method gives a semi-calibrated histogram where all the rows have the same height.
Sensors 23 02791 g010
Figure 11. Row calibration; the average-bin-width calibration is applied to the rows, resulting in a calibrated 3-D histogram with identical cell size.
Figure 11. Row calibration; the average-bin-width calibration is applied to the rows, resulting in a calibrated 3-D histogram with identical cell size.
Sensors 23 02791 g011
Figure 12. Simulation and experimental results for synchronous TDCs: the DNL after applying the calibration methods compared to the DNL of the raw TDC.
Figure 12. Simulation and experimental results for synchronous TDCs: the DNL after applying the calibration methods compared to the DNL of the raw TDC.
Sensors 23 02791 g012
Figure 13. DNL and INL values for a synchronous TDC, before and after applying the two calibration methods: (a) DNL values; (b) INL values.
Figure 13. DNL and INL values for a synchronous TDC, before and after applying the two calibration methods: (a) DNL values; (b) INL values.
Sensors 23 02791 g013
Figure 14. Calibrated histogram of a Gaussian signal—synchronous TDCs.
Figure 14. Calibrated histogram of a Gaussian signal—synchronous TDCs.
Sensors 23 02791 g014
Figure 15. Simulation and experimental results for asynchronous TDCs: the DNL after applying the calibration methods compared to the DNL of the raw TDC.
Figure 15. Simulation and experimental results for asynchronous TDCs: the DNL after applying the calibration methods compared to the DNL of the raw TDC.
Sensors 23 02791 g015
Figure 16. DNL and INL values, for an asynchronous TDC, before and after applying the two calibration methods: (a) DNL values; (b) INL values.
Figure 16. DNL and INL values, for an asynchronous TDC, before and after applying the two calibration methods: (a) DNL values; (b) INL values.
Sensors 23 02791 g016
Figure 17. Calibrated histogram of a Gaussian signal—asynchronous TDCs.
Figure 17. Calibrated histogram of a Gaussian signal—asynchronous TDCs.
Sensors 23 02791 g017
Figure 18. Fluorescence signal of a piece of paper using the two calibration methods—synchronous TDC.
Figure 18. Fluorescence signal of a piece of paper using the two calibration methods—synchronous TDC.
Sensors 23 02791 g018
Figure 19. Fluorescence signal of a piece of paper using the two calibration methods—Asynchronous TDC.
Figure 19. Fluorescence signal of a piece of paper using the two calibration methods—Asynchronous TDC.
Sensors 23 02791 g019
Table 1. DNL and INL statistics for a synchronous TDC calculated for the non-calibrated histogram and the calibrated histograms of the two methods.
Table 1. DNL and INL statistics for a synchronous TDC calculated for the non-calibrated histogram and the calibrated histograms of the two methods.
MeanMedianSTD
DNL data statisticsRaw TDC0−0.10540.7362
Bin-by-bin0−0.074530.7798
Average-bin-width0−0.00036240.009665
INL data statisticsRaw TDC0.26140.20381.676
Bin-by-bin0.0030830.0071940.4816
Average-bin-width0.00260.0066880.03167
Table 2. DNL and INL statistics for an asynchronous TDC calculated for the non-calibrated histogram and the calibrated histograms of the two methods.
Table 2. DNL and INL statistics for an asynchronous TDC calculated for the non-calibrated histogram and the calibrated histograms of the two methods.
MeanMedianSTD
DNL data statisticsNon-calibrated histogram~0−0.00490.056
Bin-by-bin calibration~0−0.00360.058
Matrix calibration~00.000330.0035
INL data statisticsNon-calibrated histogram−0.034−0.0080.14
Bin-by-bin calibration−0.0064−0.0040.045
Matrix calibration0.00360.00480.023
Table 3. Calibration processing speed comparison between the bin-by-bin method for asynchronous TDCs and the matrix calibration.
Table 3. Calibration processing speed comparison between the bin-by-bin method for asynchronous TDCs and the matrix calibration.
Total Number of Bins in Calibrated HistogramNumber of Calibrated Bins in Clock PeriodMaximum Value of COARSECalibration Process Speed (CPU Tick)Ratio (Matrix/Bin-by-Bin)
Bin-by-Bin CalibrationMatrix Calibration
460925619543,252842,229,5557.77
15372567220,704618,058,4168.18
51325631,197,7899,453,2497.89
3852562952,9217,493,4917.86
3012002959,2475,279,5255.5
2261502936,0003,681,1323.93
1511002938,1612,501,9562.67
76502930,3751,467,1801.58
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Khaddour, W.; Uhring, W.; Dadouche, F.; Dumas, N.; Madec, M. Calibration Methods for Time-to-Digital Converters. Sensors 2023, 23, 2791. https://doi.org/10.3390/s23052791

AMA Style

Khaddour W, Uhring W, Dadouche F, Dumas N, Madec M. Calibration Methods for Time-to-Digital Converters. Sensors. 2023; 23(5):2791. https://doi.org/10.3390/s23052791

Chicago/Turabian Style

Khaddour, Wassim, Wilfried Uhring, Foudil Dadouche, Norbert Dumas, and Morgan Madec. 2023. "Calibration Methods for Time-to-Digital Converters" Sensors 23, no. 5: 2791. https://doi.org/10.3390/s23052791

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop