antopwm2 2.1.0.0
Main Page

AN to PWM 2 click

‍AN to PWM 2 Click is a compact add-on board that contains an easy-to-use component that converts the value of the input analog signal to a fixed frequency PWM voltage output, with a duty cycle proportional to the input voltage. This board features the LTC6992CS6, a silicon oscillator with an easy-to-use analog voltage-controlled pulse width modulation (PWM) capability from Analog Devices. It features the PWM signal controlled by analog input in range of -2.5V to 2.5V, frequency range up to 1 MHz, frequency error less than 1.7%, and it has good temperature stability. It has many features that make it well suited for heater control, PWM servo loops, LED dimming, signal isolation, and other duty cycle control applications.

click Product page


Click library

  • Author : Stefan Filipovic
  • Date : Feb 2024.
  • Type : I2C type

Software Support

We provide a library for the AN to PWM 2 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 AN to PWM 2 Click driver.

Standard key functions :

Example key functions :

  • antopwm2_set_frequency This function sets a frequency output in a range from 500kHz to 1MHz by setting the digipot resistance.
    err_t antopwm2_set_frequency ( antopwm2_t *ctx, uint32_t freq );
    err_t antopwm2_set_frequency(antopwm2_t *ctx, uint32_t freq)
    AN to PWM 2 set frequency function.
  • antopwm2_set_frequency_otp This function sets a frequency output in a range from 500kHz to 1MHz by setting the digipot resistance in OTP mode.
    err_t antopwm2_set_frequency_otp ( antopwm2_t *ctx, uint32_t freq );
    err_t antopwm2_set_frequency_otp(antopwm2_t *ctx, uint32_t freq)
    AN to PWM 2 set frequency otp function.

Example Description

‍This example demonstrates the use of AN to PWM 2 click board by changing the PWM output frequency from 500kHz to 1MHz in steps of 50kHz.

The demo application is composed of two sections :

Application Init

‍Initializes the driver and logger.

void application_init ( void )
{
log_cfg_t log_cfg;
antopwm2_cfg_t antopwm2_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
antopwm2_cfg_setup( &antopwm2_cfg );
ANTOPWM2_MAP_MIKROBUS( antopwm2_cfg, MIKROBUS_1 );
if ( I2C_MASTER_ERROR == antopwm2_init( &antopwm2, &antopwm2_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
}
#define ANTOPWM2_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition antopwm2.h:121
void application_init(void)
Definition main.c:33

Application Task

‍Changes the PWM output frequency every 5 seconds in steps of 50kHz going through the full range from 500kHz to 1MHz. The currently set frequency will be displayed on the USB UART.

void application_task ( void )
{
static uint32_t freq = ANTOPWM2_FREQ_MIN;
if ( ANTOPWM2_OK == antopwm2_set_frequency ( &antopwm2, freq ) )
{
log_printf ( &logger, " Frequency: %lu Hz\r\n\n", freq );
}
freq += 50000;
if ( freq > ANTOPWM2_FREQ_MAX )
{
}
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
@ ANTOPWM2_OK
Definition antopwm2.h:168
#define ANTOPWM2_FREQ_MAX
AN to PWM 2 setting.
Definition antopwm2.h:93
#define ANTOPWM2_FREQ_MIN
Definition antopwm2.h:94
void application_task(void)
Definition main.c:63

Note

‍Applying a voltage of -2.5 to 2.5V on the input will generate the PWM pulse train with a duty cycle linearly proportional to the input voltage.

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.ANtoPWM2

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. UART terminal is available in all MikroElektronika compilers.