diff --git a/projects/tt_um_13hihi31_tdc/docs/architecture.png b/projects/tt_um_13hihi31_tdc/docs/architecture.png new file mode 100644 index 0000000..91708ab Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/architecture.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/coarse_delay.png b/projects/tt_um_13hihi31_tdc/docs/coarse_delay.png new file mode 100644 index 0000000..2854230 Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/coarse_delay.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/fine_delay.png b/projects/tt_um_13hihi31_tdc/docs/fine_delay.png new file mode 100644 index 0000000..72f4ecd Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/fine_delay.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/info.md b/projects/tt_um_13hihi31_tdc/docs/info.md index 2313393..88b4160 100644 --- a/projects/tt_um_13hihi31_tdc/docs/info.md +++ b/projects/tt_um_13hihi31_tdc/docs/info.md @@ -9,13 +9,41 @@ You can also include images in this folder and reference them in the markdown. E ## How it works -A Pseudo-Differential Time to Digital Converter (TDC) +The circuit includes a time-to-digital converter (TDC) and a variable delay line. The circuit's output is the TDC's result, which consists of eight stages, producing eight outputs. This chip serves no practical purpose beyond testing the TDC circuit. + +The TDC operates by utilizing flip-flops as time comparators and a delay line that generates delayed versions of the input start signal. It measures the phase difference between the start and stop signals by propagating the start signal through the delay line while using the stop signal as the clock for the flip-flops. The outputs of the flip-flops are high if the delayed start signal arrives before the stop signal and low if the delayed start signal arrives after the stop signal. By counting the number of high outputs, the phase difference between the start and stop signals can be determined with a resolution equal to one delay unit. Below is a diagram of a TDC with two stages. + +![TDC circuit](tdc.png "TDC circuit") + +The implemented TDC achieves a resolution of approximately 75 ps in post-layout simulations. Because it is challenging to provide external signals with phase differences as small as 75 ps, the circuit is designed to use a single input signal as both the start and stop signals. To test various outputs, the stop signal is delayed relative to the start signal. The architecture of the chip, featuring the TDC and the stop signal variable delay line, is shown below. + +![Circuit architecture](architecture.png "Cricuit architecture") + +The chip layout is shown below, with boxed sections corresponding to the components in the architecture diagram. + +![Layout](layout.png "Layout") + +To generate the TDC transfer curve, the start and stop signals were provided with varying phase differences. The simulation results for the TDC term_4 output are shown below. The term_4 output goes high when the phase difference between the signals is 377 ps. + +![TDC term_4 output simulation](term_4.png "TDC term_4 output simulation") + +Once the phase difference that triggers each TDC output is determined, a transfer curve can be plotted, as shown below. + +![TDC transfer curve](transfer_curve.png "TDC transfer curve") + +The stop signal delay is implemented using a variable delay line comprising fine and coarse delay stages. The fine delay stage offers a step size of 25 ps, while the coarse delay stage provides a step size of 145 ps in post-layout simulations. Below are the simulation outputs for the coarse and fine delay stages. The delay line is configured using digital inputs. The start signal also has an associated delay line, but only with fine delay stages. This additional delay allows fine-grained control when the coarse delay steps are too large, enabling smaller phase differences between signals. + +![Coarse delay](coarse_delay.png "Coarse delay") + +![Fine delay](fine_delay.png "Fine delay") ## How to test -The TDC has one analog input that is then split into start and stop signals. Because this TDC has a resolution of around 80 ps, it would be difficult to provide signals with such a small phase difference, that is why there is an extra variable delay circuit that delays the stop signal relative to the start signal. You can change the stop signal delay by configuring the digital input. To test the circuit drive the stop signal for a given configuration of delay. +The chip has one analog input, 14 digital inputs, and 8 digital outputs. To clear the TDC from a previous measurement, drive the start enable input low, and after a short delay, drive the stop input high. To test the TDC, vary the digital input values while applying a square wave to the analog stop signal. + +The fine delay is controlled using thermometer encoding, while the coarse delay is controlled using one-hot encoding. An input of all zeros is valid for both encoding schemes. ## External hardware -No external hardware needed. +Additional hardware, such as a Raspberry Pi (RPi) and a level shifter, is required to drive the analog and digital inputs. diff --git a/projects/tt_um_13hihi31_tdc/docs/layout.png b/projects/tt_um_13hihi31_tdc/docs/layout.png new file mode 100644 index 0000000..5203859 Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/layout.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/tdc.png b/projects/tt_um_13hihi31_tdc/docs/tdc.png new file mode 100644 index 0000000..aa732ce Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/tdc.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/term_4.png b/projects/tt_um_13hihi31_tdc/docs/term_4.png new file mode 100644 index 0000000..41ba053 Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/term_4.png differ diff --git a/projects/tt_um_13hihi31_tdc/docs/transfer_curve.png b/projects/tt_um_13hihi31_tdc/docs/transfer_curve.png new file mode 100644 index 0000000..a6f5433 Binary files /dev/null and b/projects/tt_um_13hihi31_tdc/docs/transfer_curve.png differ