TDC click
TDC Click is a compact add-on board that recognizes events and provides a digital representation of the time they occurred. This board features the TDC7200, a time-to-digital converter from Texas Instruments. The Time to Digital Converter (TDC) performs the function of a stopwatch and measures the elapsed time (time-of-flight or TOF) between a START pulse and up to five STOP pulses. The ability to measure from START to multiple STOPs gives users the flexibility to select which STOP pulse yields the best echo performance.
click Product page
Click library
- Author : Nenad Filipovic
- Date : Jul 2021.
- Type : SPI type
Software Support
We provide a library for the Tdc Click as well as a demo application (example), developed using MikroElektronika compilers. The demo can run on all the main MikroElektronika development boards.
Package can be downloaded/installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.
Library Description
This library contains API for Tdc Click driver.
Standard key functions :
tdc_cfg_setup
Config Object Initialization function.
void tdc_cfg_setup(tdc_cfg_t *cfg)
TDC configuration object setup function.
TDC Click configuration object.
Definition tdc.h:230
tdc_init
Initialization function.
err_t tdc_init(tdc_t *ctx, tdc_cfg_t *cfg)
TDC initialization function.
TDC Click context object.
Definition tdc.h:207
tdc_default_cfg
Click Default Configuration function.
err_t tdc_default_cfg(tdc_t *ctx)
TDC default configuration function.
Example key functions :
tdc_gen_pulse
TDC pulse generation function.
void tdc_gen_pulse(tdc_t *ctx, uint32_t u_sec, uint8_t n_stops)
TDC pulse generation function.
tdc_setup_measurement
DC setup measurement function.
err_t tdc_setup_measurement(tdc_t *ctx, uint8_t cal_periods, uint8_t avg_cycles, uint8_t num_stops, uint8_t mode)
TDC setup measurement function.
tdc_get_measurement
TDC get measurement function. err_t
tdc_get_measurement (
tdc_t *ctx, uint8_t clock_mode, uint8_t measure_num_stop, uint32_t *time, uint32_t *clock_countn, uint32_t *tof );
err_t tdc_get_measurement(tdc_t *ctx, uint8_t clock_mode, uint8_t measure_num_stop, uint32_t *time, uint32_t *clock_countn, uint32_t *tof)
TDC get measurement function.
Example Description
This library contains an API for the TDC Click driver. This demo application shows the use of a TDC Click boardâ„¢.
The demo application is composed of two sections :
Application Init
Initialization of SPI module and log UART. After driver initialization, the app set default settings and the configures the measurement ( set the pulse to 100 us ).
{
log_cfg_t log_cfg;
static uint8_t cal_periods;
static uint8_t avg_cycles;
static uint8_t sel_mode;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
err_t init_flag =
tdc_init( &tdc, &tdc_cfg );
init_flag |=
tdc_init( &tdc_pulse, &tdc_cfg1 );
if ( SPI_MASTER_ERROR == init_flag )
{
log_error( &logger, " Application Init Error. " );
log_info( &logger, " Please, run program again... " );
for ( ; ; );
}
log_info( &logger, " Application Task " );
Delay_ms ( 100 );
cal_periods = 10;
avg_cycles = 1;
num_stops = 3;
sel_mode = 1;
pulse_us = 100;
count_stop = 1;
log_printf( &logger, "---------------------------\r\n" );
Delay_ms ( 100 );
}
#define TDC_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition tdc.h:187
void application_init(void)
Definition main.c:38
Application Task
This is an example that shows the use of a TDC Click boardâ„¢. In this example, after the START signal, the app sends 3 STOP signals per 100 microseconds. The application reads and displays the value of Time, Clock count and Time-of-Flight values of three performed measurements. Results are being sent to the Usart Terminal where you can track their changes.
{
static uint32_t p_time[ 5 ];
static uint32_t p_clock_count[ 5 ];
static uint32_t p_tof[ 5 ];
log_printf( &logger, " Time[ 0 ] = %lu\r\n", p_time[ 0 ] );
log_printf( &logger, " Time[ 1 ] = %lu\r\n", p_time[ 1 ] );
log_printf( &logger, " Time[ 2 ] = %lu\r\n", p_time[ 2 ] );
log_printf( &logger, "- - - - - - - - - - - - - -\r\n" );
log_printf( &logger, " Clock count[ 0 ] = %lu\r\n", p_clock_count[ 0 ] );
log_printf( &logger, " Clock count[ 1 ] = %lu\r\n", p_clock_count[ 1 ] );
log_printf( &logger, " Clock count[ 2 ] = %lu\r\n", p_clock_count[ 2 ] );
log_printf( &logger, "- - - - - - - - - - - - - -\r\n" );
log_printf( &logger, " TOF[ 0 ] = %u us\r\n", p_tof[ 0 ] );
log_printf( &logger, " TOF[ 1 ] = %u us\r\n", p_tof[ 1 ] );
log_printf( &logger, " TOF[ 2 ] = %u us\r\n", p_tof[ 2 ] );
log_printf( &logger, "---------------------------\r\n" );
Delay_ms ( 1000 );
}
#define TDC_MCU_CLOCK_MODE_168_MHZ
Definition tdc.h:167
uint8_t tdc_get_trg(tdc_t *ctx)
TDC get trigger signal function.
void tdc_start_measurement(tdc_t *ctx)
TDC start measurement function.
uint8_t tdc_get_interrupt(tdc_t *ctx)
TDC get interrupt function.
void application_task(void)
Definition main.c:91
The full application code, and ready to use projects can be installed directly from NECTO Studio Package Manager(recommended way), downloaded from our LibStock™ or found on Mikroe github account.
Other Mikroe Libraries used in the example:
- MikroSDK.Board
- MikroSDK.Log
- Click.Tdc
Additional notes and informations
Depending on the development board you are using, you may need USB UART click, USB UART 2 Click or RS232 Click to connect to your PC, for development systems with no UART to USB interface available on the board. The terminal available in all MikroElektronika compilers, or any other terminal application of your choice, can be used to read the message.