.. note::
Ciao, benvenuto nella SunFounder Raspberry Pi & Arduino & ESP32 Enthusiasts Community su Facebook! Approfondisci Raspberry Pi, Arduino ed ESP32 insieme ad altri appassionati.
**Perché unirti a noi?**
- **Supporto esperto**: Risolvi i problemi post-vendita e le sfide tecniche con l'aiuto della nostra comunità e del nostro team.
- **Impara e Condividi**: Scambia suggerimenti e tutorial per migliorare le tue competenze.
- **Anteprime esclusive**: Ottieni accesso anticipato a nuovi annunci di prodotti e anteprime esclusive.
- **Sconti speciali**: Approfitta di sconti esclusivi sui nostri prodotti più recenti.
- **Promozioni festive e omaggi**: Partecipa a omaggi e promozioni durante le festività.
👉 Pronto per esplorare e creare con noi? Clicca su [|link_sf_facebook|] e unisciti oggi stesso!
.. _2.2.9_js:
2.2.9 Modulo MPU6050
========================
Introduzione
-----------------
Il MPU-6050 è il primo e unico dispositivo di tracciamento del movimento a 6 assi al
mondo (giroscopio a 3 assi e accelerometro a 3 assi) progettato per smartphone, tablet
e sensori indossabili che richiedono queste caratteristiche, tra cui basso consumo
energetico, basso costo e alte prestazioni.
In questo esperimento, utilizziamo I2C per ottenere i valori del sensore di accelerazione
a tre assi e del giroscopio a tre assi del MPU6050 e visualizzarli sullo schermo.
Componenti necessari
-------------------------
In questo progetto, abbiamo bisogno dei seguenti componenti.
.. image:: ../img/list_2.2.6.png
È sicuramente conveniente acquistare un kit completo, ecco il link:
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nome
- ELEMENTI IN QUESTO KIT
- LINK
* - Kit Raphael
- 337
- |link_Raphael_kit|
Puoi anche acquistarli separatamente dai link qui sotto.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUZIONE AI COMPONENTI
- LINK DI ACQUISTO
* - :ref:`cpn_gpio_extension_board`
- |link_gpio_board_buy|
* - :ref:`cpn_breadboard`
- |link_breadboard_buy|
* - :ref:`cpn_wires`
- |link_wires_buy|
* - :ref:`cpn_mpu6050`
- |link_mpu6050_buy|
Schema elettrico
--------------------
MPU6050 comunica con il microcontrollore tramite l'interfaccia bus I2C.
SDA1 e SCL1 devono essere collegati al pin corrispondente.
.. image:: ../img/image330.png
Procedure sperimentali
--------------------------
**Passo 1:** Costruisci il circuito.
.. image:: ../img/image227.png
**Passo 2:** Configura I2C (vedi Appendice :ref:`i2c_config`. Se hai già configurato
I2C, salta questo passaggio).
**Passo 2:** Vai alla cartella del codice.
.. raw:: html
.. code-block::
cd ~/raphael-kit/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
Con l'esecuzione del codice, l'angolo di deviazione degli assi x e y e l'accelerazione
e la velocità angolare su ciascun asse letti dal MPU6050 verranno stampati sullo schermo
dopo essere stati calcolati.
**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 );
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``, determina l'indirizzo del MPU6050 e il bus e
crea l'oggetto gyro, rendendo conveniente chiamare le funzioni incapsulate nel modulo.
.. note::
Per maggiori informazioni su questo 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()``: Restituisce un oggetto JSON con i dati grezzi x, y, z dal giroscopio.
``gyro.get_accel_xyz()``: Restituisce un oggetto JSON con i dati grezzi x, y, z dall'accelerometro.
``gyro.get_roll_pitch( gyro_xyz, accel_xyz )``: Restituisce un oggetto JSON con rollio e beccheggio in gradi.
Immagine del fenomeno
-------------------------
.. image:: ../img/image228.jpeg