Load cell 2 Click is a weight measurement click which utilizes a load cell element, in order to precisely measure the weight of an object. The Load Cell 2 Click can be used with the strain gauge type of load cells with external differential reference voltage range from 0.1V to 5V.
We provide a library for the LoadCell2 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 form compilers IDE(recommended way), or downloaded from our LibStock, or found on mikroE github account.
{
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_printf( &logger, " - Application Init - \r\n" );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Load cell click \r\n");
log_printf( &logger, "-------------------------\r\n");
Delay_ms ( 100 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Reset all registers \r\n");
Delay_ms ( 100 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Power On \r\n");
Delay_ms ( 100 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Set default config. \r\n");
Delay_ms ( 100 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Calibrate AFE \r\n");
Delay_ms ( 1000 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Tare the scale : \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " >> Remove all object << \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " In the following 10 sec \r\n");
log_printf( &logger, " please remove all object\r\n");
log_printf( &logger, " from the scale. \r\n");
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Start tare scales \r\n");
Delay_ms ( 500 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Tarring is complete \r\n");
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Calibrate Scale : \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " >>> Load etalon <<< \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " In the following 10 sec \r\n");
log_printf( &logger, "place 1000g weight etalon\r\n");
log_printf( &logger, " on the scale for \r\n");
log_printf( &logger, " calibration purpose. \r\n");
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Start calibration \r\n");
{
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Calibration Done \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " >>> Remove etalon <<< \r\n");
log_printf( &logger, "- - - - - - - - - - - - -\r\n");
log_printf( &logger, " In the following 10 sec \r\n");
log_printf( &logger, " remove 1000g weight \r\n");
log_printf( &logger, " etalon on the scale. \r\n");
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
Delay_ms ( 1000 );
}
else
{
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Calibration Error \r\n");
for ( ; ; );
}
log_printf( &logger, "-------------------------\r\n");
log_printf( &logger, " Start measurements : \r\n");
log_printf( &logger, "-------------------------\r\n");
}
#define LOADCELL2_WEIGHT_1000G
Definition loadcell2.h:210
#define LOADCELL2_MAP_MIKROBUS(cfg, mikrobus)
Definition loadcell2.h:65
void loadcell2_cfg_setup(loadcell2_cfg_t *cfg)
Config Object Initialization function.
LOADCELL2_RETVAL loadcell2_init(loadcell2_t *ctx, loadcell2_cfg_t *cfg)
Initialization function.
uint8_t loadcell2_calibration(loadcell2_t *ctx, uint16_t cal_val, loadcell2_data_t *cell_data)
Calibration function.
void loadcell2_default_cfg(loadcell2_t *ctx)
Click Default Configuration function.
void loadcell2_tare(loadcell2_t *ctx, loadcell2_data_t *cell_data)
Tare function.
void loadcell2_calibrate_afe(loadcell2_t *ctx)
Calibrate analog front end of system function.
LOADCELL2_RETVAL loadcell2_power_on(loadcell2_t *ctx)
Power On function.
void loadcell2_reset(loadcell2_t *ctx)
Reset function.
#define LOADCELL2_GET_RESULT_OK
Definition loadcell2.h:201
void application_init(void)
Definition main.c:44
Click configuration structure definition.
Definition loadcell2.h:254
The full application code, and ready to use projects can be installed directly form compilers IDE(recommneded) or found on LibStock page or mikroE GitHub accaunt.