lsm9ds1 — IMU de 9 eixos LSM9DS1¶
Driver para o módulo inercial iNEMO ST LSM9DS1 via I2C. O LSM9DS1 combina um acelerómetro de 3 eixos, um giroscópio de 3 eixos e um magnetómetro de 3 eixos num único encapsulamento; o acelerómetro e o giroscópio partilham um endereço I2C, enquanto o magnetómetro responde num segundo endereço. Este driver também ativa o FIFO de 16 posições de giroscópio/acelerómetro no chip, para que as amostras mais recentes possam ser drenadas eficientemente através de iter_accel_gyro().
Exemplo:
import time
from machine import Pin, I2C
from lsm9ds1 import LSM9DS1
imu = LSM9DS1(I2C(1, scl=Pin("P15"), sda=Pin("P14")))
while True:
print("Accelerometer: x:{:>8.3f} y:{:>8.3f} z:{:>8.3f}".format(*imu.accel()))
print("Magnetometer: x:{:>8.3f} y:{:>8.3f} z:{:>8.3f}".format(*imu.magnet()))
print("Gyroscope: x:{:>8.3f} y:{:>8.3f} z:{:>8.3f}".format(*imu.gyro()))
time.sleep_ms(100)
Classes¶
- class lsm9ds1.LSM9DS1(bus: machine.I2C, address_imu: int = 0x6B, address_magnet: int = 0x1E, gyro_odr: float = 952, gyro_scale: int = 245, accel_odr: float = 952, accel_scale: int = 4, magnet_odr: int = 80, magnet_scale: int = 4)¶
Constrói uma instância
LSM9DS1, verifica os registos WHO_AM_I de ambos os sub-dispositivos, configura os três sensores e ativa o FIFO accel/gyro em modo contínuo.busUm barramento
machine.I2Cconfigurado ao qual o sensor está ligado.address_imuEndereço I2C de 7 bits do sub-dispositivo acelerómetro/giroscópio. Por omissão é
0x6B.address_magnetEndereço I2C de 7 bits do sub-dispositivo magnetómetro. Por omissão é
0x1E.gyro_odrTaxa de saída de dados do giroscópio em Hz. Deve ser um dos seguintes valores:
0(desligado),14.9,59.5,119,238,476ou952.gyro_scaleGama de escala completa do giroscópio em graus por segundo. Deve ser um dos seguintes valores:
245,500ou2000.accel_odrTaxa de saída de dados do acelerómetro em Hz. Mesmo conjunto de valores que
gyro_odr.accel_scaleGama de escala completa do acelerómetro em g. Deve ser um dos seguintes valores:
2,4,8ou16.magnet_odrTaxa de saída de dados do magnetómetro em Hz. Deve ser um dos seguintes valores:
0.625,1.25,2.5,5,10,20,40ou80.magnet_scaleGama de escala completa do magnetómetro em gauss. Deve ser um dos seguintes valores:
4,8,12ou16.
- calibrate_magnet(offset: tuple[float, float, float]) None¶
Escreve um vetor de offset de ferro duro nos registos
OFFSET_REG_*_Mdo magnetómetro. O offset é fornecido nas mesmas unidades quemagnet()devolve (gauss); cada componente é convertido para LSB em bruto usando a escala do magnetómetro configurada antes de ser escrito.
- gyro_id() bytes¶
Devolve o valor do registo
WHO_AM_Ide um byte do sub-dispositivo acelerómetro/giroscópio.