= Attaching a LIS3DH Nano Accelerometer via i2c. This example shows you how to interface the Raspberry Pi Pico to the LIS3DH accelerometer and temperature sensor. ====== The code reads and displays the acceleration values of the board in the 3 axes and the ambient temperature value. The datasheet for the sensor can be found at https://www.st.com/resource/en/datasheet/cd00274221.pdf. The device is being operated on 'normal mode' and at a frequency of 1.344 kHz (this can be changed by editing the ODR bits of CTRL_REG4). The range of the data is controlled by the FS bit in CTRL_REG4 and is equal to ±2g in this example. The sensitivity depends on the operating mode and data range; exact values can be found on page 10 of the datasheet. In this case, the sensitivity value is 4mg (where g is the value of gravitational acceleration on the surface of Earth). In order to use the auxiliary ADC to read temperature, the we must set the BDU bit to 1 in CTRL_REG4 and the ADC_EN bit to 1 in TEMP_CFG_REG. Temperature is communicated through ADC 3. ====== [NOTE] ====== The sensor doesn't have features to eliminate any offsets in the data and they would be needed to be taken into account in the code. ====== == Wiring information Wiring up the device requires 4 jumpers, to connect VIN, GND, SDA and SCL. The example here uses I2C port 0, which is assigned to GPIO 4 (SDA) and 5 (SCL) in software. Power is supplied from the 3V pin. [[lis3dh_i2c_wiring]] [pdfwidth=75%] .Wiring Diagram for LIS3DH. image::lis3dh_i2c.png[] == List of Files CMakeLists.txt:: CMake file to incorporate the example in to the examples build tree. lis3dh_i2c.c:: The example code. == Bill of Materials .A list of materials required for the example [[lis3dh-bom-table]] [cols=3] |=== | *Item* | *Quantity* | Details | Breadboard | 1 | generic part | Raspberry Pi Pico | 1 | https://www.raspberrypi.com/products/raspberry-pi-pico/ | LIS3DH board| 1 | https://www.adafruit.com/product/2809 | M/M Jumper wires | 4 | generic part |===