.. note:: Ciao, benvenuto nella SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts Community su Facebook! Unisciti a noi per approfondire Raspberry Pi, Arduino e ESP32 insieme ad altri appassionati. **Perché unirsi a noi?** - **Supporto esperto**: Risolvi problemi post-vendita e sfide tecniche con l'aiuto della nostra community e del nostro team. - **Impara e condividi**: Scambia suggerimenti e tutorial per migliorare le tue competenze. - **Anteprime esclusive**: Accedi in anticipo agli annunci di nuovi prodotti e anteprime. - **Sconti speciali**: Approfitta di sconti esclusivi sui nostri prodotti più recenti. - **Promozioni e omaggi festivi**: Partecipa a omaggi e promozioni per le festività. 👉 Pronto a esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso! 2.2.6 Modulo MPU6050 ======================== Introduzione --------------- L’MPU-6050 è il primo e unico dispositivo al mondo per il rilevamento del movimento a 6 assi (3 assi per giroscopio e 3 assi per accelerometro) progettato per smartphone, tablet e sensori indossabili. È dotato di caratteristiche che includono bassi consumi energetici, bassi costi e elevate prestazioni. In questo esperimento, utilizziamo I2C per ottenere i valori del sensore di accelerazione a tre assi e del giroscopio a tre assi del modulo MPU6050 e li mostriamo sullo schermo. Componenti ------------- .. image:: ../img/list_2.2.6.png Schema Elettrico ------------------- L'MPU6050 comunica con il microcontrollore attraverso l'interfaccia bus I2C. SDA1 e SCL1 devono essere collegati ai rispettivi pin. .. image:: ../img/image330.png Procedura Sperimentale ------------------------ **Passo 1:** Monta il circuito. .. image:: ../img/image227.png **Passo 2**: Configura I2C (consulta l'Appendice :ref:`i2c_config`. Se hai già configurato I2C, salta questo passo.) **Passo 2:** Vai alla cartella del codice. .. raw:: html .. code-block:: cd ~/davinci-kit-for-raspberry-pi/nodejs/ **Passo 3:** Installa le dipendenze. .. raw:: html .. code-block:: sudo npm install mpu6050-gyro **Passo 4:** Esegui il codice. .. raw:: html .. code-block:: sudo node mpu6050_module.js Quando il codice è in esecuzione, l'angolo di inclinazione sugli assi x e y e l’accelerazione e velocità angolare su ciascun asse rilevati da MPU6050 verranno calcolati e stampati sullo schermo. **Codice** .. code-block:: js var gyro = require("mpu6050-gyro"); var address = 0x68; //MPU6050 address var bus = 1; //i2c bus used var gyro = new gyro( bus,address ); async function update_telemetry() { var gyro_xyz = gyro.get_gyro_xyz(); var accel_xyz = gyro.get_accel_xyz(); var gyro_data = { gyro_xyz: gyro_xyz, accel_xyz: accel_xyz, rollpitch: gyro.get_roll_pitch( gyro_xyz, accel_xyz ) } console.log(gyro_data); setTimeout(update_telemetry, 500); } if ( gyro ) { update_telemetry(); } **Spiegazione del Codice** .. code-block:: js var gyro = require("mpu6050-gyro"); var address = 0x68; // Indirizzo MPU6050 var bus = 1; // Bus i2c utilizzato var gyro = new gyro(bus, address); Importa il modulo ``mpu6050-gyro``, definisci l'indirizzo di MPU6050 e crea un oggetto gyro per richiamare le funzioni incapsulate nel modulo. .. note:: Per maggiori dettagli sul modulo, consulta: https://www.npmjs.com/package/mpu6050-gyro .. code-block:: js var gyro_xyz = gyro.get_gyro_xyz(); var accel_xyz = gyro.get_accel_xyz(); var gyro_data = { gyro_xyz: gyro_xyz, accel_xyz: accel_xyz, rollpitch: gyro.get_roll_pitch( gyro_xyz, accel_xyz ) } console.log(gyro_data); setTimeout(update_telemetry, 500); Il modulo incapsula tre funzioni disponibili: ``gyro.get_gyro_xyz()``: Ritorna un oggetto JSON con i dati x, y, z grezzi del giroscopio. ``gyro.get_accel_xyz()``: Ritorna un oggetto JSON con i dati x, y, z grezzi dell'accelerometro. ``gyro.get_roll_pitch(gyro_xyz, accel_xyz)``: Ritorna un oggetto JSON con i valori di rollio e beccheggio in gradi. Immagine del Fenomeno ------------------------ .. image:: ../img/image228.jpeg