HTS221_library Files for All Microcontrollers

by ANKL in Teachers > Coding

567 Views, 1 Favorites, 0 Comments

HTS221_library Files for All Microcontrollers

markus-spiske-1LLh8k2_YFk-unsplash.jpg
pexels-polina-zimmerman-3747535.jpg

Hello everyone Recently I made a library for HTS221 which is a Capacitive digital sensor for measuring relative humidity and temperature. I have also mentioned for all MCU making it compatible with other controllers is not a big deal if you see a liquid crystal display with the help of library files available online you can use such LCD with almost all type of microcontrollers.

Similarly my library files contains sets of functions with can be used on almost all the microcontrollers, For controllers like SMT32 which widely uses HAL library or LL library this requires another set of library files which act as a mediator to access the hardware peripheral for HTS221 library file.

Example:
To drive a liquid crystal display we use library files such as "LiquidCrystal.h" and "wire.h" library to communicate with I2C enabled devices and sensors.

Supplies

STM32 development board( any with I2c)

HTS221 sensor

CubeIDE latest version(works fine with some old versions)

What Is a Library File

what is a function?

Functions are set of code that accomplish a specific task. Functions usually "take in" data, process it, and "return" a result. Once a function is written, it can be used over and over and over again. Functions can be "called" from the inside of other functions.

Library

Libraries in programming languages are collections of prewritten code that users can use to organize simplify there task. usually library contains functions and variable.

About HTS221 Sensor

HTS221_I2CS_A_1.png
adafruit_products_4535_iso_ORIG_2020_03_edit.jpg

HTS221 is a Temperature and Humidity sensor by STmicroelectronics

Description
The HTS221 is an ultra-compact sensor for relative humidity and temperature. It includes a sensing element and a mixed signal ASIC to provide the measurement information through digital serial interfaces. The sensing element consists of a polymer dielectric planar capacitor structure capable of detecting relative humidity variations and is manufactured using a dedicated ST process.

Key Features:

 16-bit humidity and temperature output data

 SPI and I²C interfaces

 Factory calibrated

For more information Download the Datasheet "CLICK HERE"

About HTS221-Library File

fk0849hvg2rt13bpqhjy.jpg

The library was created in C language. The entire library can be downloaded from Github along with that the project also contains the project file for STM32l151RE/152RE.

MAIN FILES:

HTS221_anklabs.h

HTS221_anklabs.c

These files allows us to Read/Write registers and performs post calibration on output data.

SUPPORTING FILES:

HAL_I2C_anklabs.h

HAL_I2C_anklabs.c

These files make possible for HTS221-library to access resources STmicroelectronics HAL Library. Note: This files can only be used to Acess I2C Resources. If you wish to use SPI you should use "HAL_SPI_anklabs" library files.

HTS221_anklabs library consists of 52 variable declarations for HTS221 Registers and 10 functions. HAL_I2C_anklabs version 1 consists of 3 functions and a struct variable.

How to Use HTS221-Lib File

Screenshot (22).png

How to use HTS221-Lib file

  • Open project workspace in your prefered toolchain.
  • Include HTS221_anklabs.h along with the rest of the .h files in your tool chain, you can create separate folder to place this files but the linker should be able to locate your files.
  • The same process applies for HTS221_anklabs.c
  • Include "#include

How to use HTS221-API files for HAL_libarary based STM32 controllers

  • CubeIDE and IAR embedded are the prefered toolcains but it will work fine with keil and other IDE too.
  • The same instructions follows as explained earlier and include "#include".
  • A small modification for the header file is essential when ever your are using different STM32 controllers.
  • Open HAL_I2C_anklabs.h file and modify the header file.

Example:

  • if your are using STM32l1xx - #include "stm32l1xx_hal.h"
  • if your are using STM32G4xx - #include "stm32g4xx_hal.h"
  • if your are using STM32F7xx - #include "stm32f7xx_hal.h"
  • if your are using STM32H7xx - #include "stm32h7xx_hal.h"
  • if your are using STM32l4xx - #include "stm32l4xx_hal.h"

etc.

HTS221 Supporting Functions

Screenshot (23).png

HTS221_I();

  • Initializes the sensor and allows the user to change the output data rate.
  • Sets ODR to 1Hz(default).

Input parameter - no input Arguments(updating....)

Output parameter - void

HTS221_Dev_ID();

  • Returns the Device ID of HTS221 Sensor.

Input parameter - no input Arguments.

Output parameter - Returns Device ID(uint8_t)

HTS221_Detected();

  • Returns 1 when HTS221 is detected.
  • Returns 0 when HTS221 is not detected.

Input parameter - no input Arguments.

Output parameter - Returns 0 or 1(uint8_t)

HTS221_Average_func();

  • Performs Average for Temperature and Humidity values internally.
  • Makes 16 Temperature Average and 32 Humidity average.

Input parameter - No input Arguments

Output parameter - void

HTS221_Start_conversion();

  • In oneshot mode the conversion has to be started manually.
  • After every ADC conversion Bit0 of Control register 2 in HTS221 sets to 0.
  • This function sets the required bits and starts the conversion.

Input parameter - No input parameter.

Output parameter - void

HTS221_Data_Ready_T();

  • This functions check the availability of Temperature data.
  • When the users reads the data, the output will be zero when the ADC conversion has not completed.
  • After a successful read the data stored in the register sets to zero.
  • This function will make sure that the user reads the valid data.

Input parameter - No input parameter.

Output parameter - Returns 1 or 0 (uint8_t)

HTS221_Data_Ready_H();

  • Same as before but this time it will check the availability of Humidity data.

Input parameter - No input parameter.

Output parameter - Returns 1 or 0 (uint8_t)

HTS221_Data_Ready();

  • This function will check the availability of Temperature and Humidity data.

Input parameter - No input parameter.

Output parameter - Returns 1 or 0 (uint8_t)

HTS221_Read_temp();

  • Reads the 16-bit Temperature data from HTS221.
  • Performs linear interpolation.

Input parameter - No input parameter.

Output parameter - Returns calibrated Temperature data(uint32_t)

HTS221_Read_humi();

  • Reads the 16-bit Humidity data from HTS221.
  • Performs linear interpolation.

Input parameter - No input parameter.

Output parameter - Returns calibrated Humidity data(uint32_t)

DOWNLOAD ZONE

Download HTS221-Datasheet "CLICK HERE"

Downlaod HTS221-Library Files "CLICK HERE"