materiels:temps:htr:htri2c

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
materiels:temps:htr:htri2c [2024/05/04 09:39] – [3.3 Exemples de code] philmateriels:temps:htr:htri2c [2024/07/30 17:37] (Version actuelle) – [Matériels - Horloge Temps Réel (HTR) I²C] phil
Ligne 4: Ligne 4:
 ===== Matériels - Horloge Temps Réel (HTR) I²C ===== ===== Matériels - Horloge Temps Réel (HTR) I²C =====
  
-[Mise à jour le 3/5/2024]+[Mise à jour le 30/7/2024] 
 + 
 +\\ 
  
 === Lecture connexe === === Lecture connexe ===
Ligne 10: Ligne 13:
  
 \\ \\
- 
  
 ==== 1. Généralités ==== ==== 1. Généralités ====
Ligne 22: Ligne 24:
  
 === 2.1 Généralités === === 2.1 Généralités ===
-  * **Description**+  * //**Description**//
 L'horloge temps réel (RTC) à circuit DS1307 est une **horloge / calendrier BCD** (décimal codé binaire) disposant de **56 octets de NV SRAM**. Elle communique avec un microcontrôleur via un bus I2C. \\ Ce circuit fournit l'année, le mois, le jour, les heures, les minutes et  les secondes en tenant compte des années bissextiles. L'horloge fonctionne au format 24 heures ou 12 heures avec l'indication AM / PM. Un circuit de détection de puissance intégré passe automatiquement sur une alimentation de secours en cas de coupure du courant. L'horloge temps réel (RTC) à circuit DS1307 est une **horloge / calendrier BCD** (décimal codé binaire) disposant de **56 octets de NV SRAM**. Elle communique avec un microcontrôleur via un bus I2C. \\ Ce circuit fournit l'année, le mois, le jour, les heures, les minutes et  les secondes en tenant compte des années bissextiles. L'horloge fonctionne au format 24 heures ou 12 heures avec l'indication AM / PM. Un circuit de détection de puissance intégré passe automatiquement sur une alimentation de secours en cas de coupure du courant.
  
-  * **Brochage**+  * //**Brochage**//
 {{ :materiels:temps:htr:brocheds1307.png?nolink&200 |}} {{ :materiels:temps:htr:brocheds1307.png?nolink&200 |}}
  
-  * **Schéma**+  * //**Application typique**//
 {{ :materiels:temps:htr:schds1307.png?nolink&400 |}} {{ :materiels:temps:htr:schds1307.png?nolink&400 |}}
  
 {{ :materiels:capteurs:acrobate.gif?nolink&40|}} {{ :materiels:capteurs:acrobate.gif?nolink&40|}}
-  * ** Documentation **+  * //** Documentation **//
       * **Datasheet** du circuit DS1307 à télécharger <html><a href="http://www.microbot.it/documents/ds1307.pdf" target="_blank"><b>ici</a></b></html>.       * **Datasheet** du circuit DS1307 à télécharger <html><a href="http://www.microbot.it/documents/ds1307.pdf" target="_blank"><b>ici</a></b></html>.
  
Ligne 93: Ligne 95:
  
 <pane id="tab-ds1307duino_2"> <pane id="tab-ds1307duino_2">
 +{{ :materiels:capteurs:distance:arduinoico.png?nolink&40|}}
   * //**Exemple** de l'IDE Arduino pour tester le capteur// \\ Dans l'IDE Arduino, sélectionner : Fichier → Exemples → RTClib -> **DS1307**   * //**Exemple** de l'IDE Arduino pour tester le capteur// \\ Dans l'IDE Arduino, sélectionner : Fichier → Exemples → RTClib -> **DS1307**
 </pane> </pane>
Ligne 148: Ligne 151:
     * Dimensions: 22,5 x 21 mm     * Dimensions: 22,5 x 21 mm
    
 +  * //**Application typique**//
 +{{ :materiels:temps:htr:appli_typique_ds3231m.png?nolink |}}
 +
 +  * //**Schéma-blocs**//
 +{{ :materiels:temps:htr:ds3231m_bloc_diagram.png?nolink |}}
 +
 +
   * //**Signaux**//   * //**Signaux**//
 +    * SCL, SDA : clock et data du bus I2C 
     * INT : interruption en sortie de niveau bas ou d'onde carrée de 1 Hz     * INT : interruption en sortie de niveau bas ou d'onde carrée de 1 Hz
     * RST : Réinitialisation du processeur     * RST : Réinitialisation du processeur
     * 32K : Sortie  32,768 kHz     * 32K : Sortie  32,768 kHz
 + 
 +<callout type="warning" title="Interruption" icon="true">Voir <html><b><a href="https://www.arduino.cc/reference/en/language/functions/external-interrupts/attachinterrupt/" target="_blank">attachInterrupt()</a></b></html> pour la correspondance entre les numéros d'interruption et les broches d'E/S.</callout>
  
 {{ :materiels:capteurs:acrobate.gif?nolink&40|}} {{ :materiels:capteurs:acrobate.gif?nolink&40|}}
   * //**Documentation**//    * //**Documentation**// 
     * Datasheet à télécharger <html><a href="https://www.analog.com/media/en/technical-documentation/data-sheets/DS3231M.pdf" target="_blank"><b>ici</b></a></html>     * Datasheet à télécharger <html><a href="https://www.analog.com/media/en/technical-documentation/data-sheets/DS3231M.pdf" target="_blank"><b>ici</b></a></html>
 +
 +{{ :materiels:capteurs:environnement:iconechronogrammes.png?nolink&50|}}
 +  * //**Chronogrammes**//
 +    * Relevé des signaux du bus I2C faite lors d'une configuration du circuit pour générer un signal 1HZ sur INT. A télécharger <html><a href="https://webge.fr/doc/wikis/img/Mesures_DS3231M.zip" target="_blank"><b>ici</b></a></html>
  
 \\ \\
Ligne 182: Ligne 199:
  
 <pane id="tab-ds3231mduino_2"> <pane id="tab-ds3231mduino_2">
-  * //**Ressources**// <html><a href="https://wiki.dfrobot.com/DS3231M%20MEMS%20Precise%20RTC%20SKU:%20DFR0641" target="_blank"><b>Wiki</b></a></html> DFROBOT | <html><a href="https://www.arduino.cc/reference/en/language/functions/external-interrupts/attachinterrupt/" target="_blank">attachInterrupt()</a></html> | <html><a href="https://www.arduino.cc/reference/en/language/functions/external-interrupts/digitalpintointerrupt/" target="_blank">digitalPinToInterrupt()</a></html>+  * //**Ressources**// 
 +    * <html><a href="https://wiki.dfrobot.com/DS3231M%20MEMS%20Precise%20RTC%20SKU:%20DFR0641" target="_blank"><b>Wiki</b></a></html> DFROBOT | <html><a href="https://www.arduino.cc/reference/en/language/functions/external-interrupts/attachinterrupt/" target="_blank">attachInterrupt()</a></html> | <html><a href="https://www.arduino.cc/reference/en/language/functions/external-interrupts/digitalpintointerrupt/" target="_blank">digitalPinToInterrupt()</a></html>{{ :materiels:capteurs:intensite:doc.gif?nolink|}} 
 +    * //**Fiche guide**// pour l'étude d'une chaîne d'information comprenant une HTR **DS3231M** <html><a href="https://webge.fr/doc/projets/tsin/0_Fiches guide TSIN/TSIN_FGA_DS3231M.zip">[Télécharger]</a></html> 
 + 
 +  * //**Connexion**// à une <html><a href="https://wiki.seeedstudio.com/Base_Shield_V2/" target="_blank">Base Shield V2</a></html> montée sur une Arduino Uno \\ {{ :materiels:temps:htr:ds3231m_arduino.jpg?nolink&500 |}}
  
   * //**Exemple** pour tester l'HTR// \\    * //**Exemple** pour tester l'HTR// \\ 
 +{{ :materiels:capteurs:distance:arduinoico.png?nolink&40|}}
 <code cpp *.cpp> <code cpp *.cpp>
-// Code testé sur Arduino Uno et Arduino MKR 0+// Code testé sur Arduino Uno et Arduino MKR Zéro
 // Interruption générée toutes le 1s par une HTR à DS3231M // Interruption générée toutes le 1s par une HTR à DS3231M
  
 #include "DFRobot_DS3231M.h" #include "DFRobot_DS3231M.h"
  
-const byte interruptPin = 2// 6 pour la MKR Zéro, MKR 1010+// Broche utilisée pour l'interruption 
 +// Arduino UNO : 2 (D2) 
 +// Arduino MKR0 ou MKR Wifi1010 : 0 (D0) 
 +const byte interruptPin = 0; 
 int i=0; int i=0;
  
Ligne 197: Ligne 223:
  
 void setup() { void setup() {
-  pinMode(interruptPin, INPUT_PULLUP); // INT du circuit DS3231M sur drain ouvert +  pinMode(interruptPin, INPUT_PULLUP);  // INT du circuit DS3231M sur drain ouvert 
-  Serial.begin(115200); +  Serial.begin(115200); // Sortie dans la console 
-  /*On attend que l'initialisation du DS3231M soit complète*/+  /* On attend que l'initialisation du DS3231M soit complète */
   while (rtc.begin() != true) {   while (rtc.begin() != true) {
     Serial.println("Circuit non initialisé, vérifier les connexions. ");     Serial.println("Circuit non initialisé, vérifier les connexions. ");
Ligne 205: Ligne 231:
   }   }
   /*!   /*!
-     *@brief Set the value of pin sqw +     *@brief Broche INT 
-     *@param mode eDS3231M_OFF             = 0x01 // Not output square waveenter interrupt mode +     *@param mode eDS3231M_OFF             = 0x01 // Désactivation du signal en sortieDS3231M en mode interruption 
-     *@n          eDS3231M_SquareWave_1Hz  = 0x00 // 1Hz square wave +     *@n          eDS3231M_SquareWave_1Hz  = 0x00 // signal carré 1Hz  
-     *@n          eDS3231M_SquareWave_1kHz = 0x08 // 1kHz square wave +     *@n          eDS3231M_SquareWave_1kHz = 0x08 // signal carré 1kHz  
-     *@n          eDS3231M_SquareWave_4kHz = 0x10 // 4kHz square wave +     *@n          eDS3231M_SquareWave_4kHz = 0x10 // signal carré 4kHz  
-     *@n          eDS3231M_SquareWave_8kHz = 0x18 // 8kHz square wave+     *@n          eDS3231M_SquareWave_8kHz = 0x18 // signal carré 8kHz 
      */      */
   rtc.writeSqwPinMode(eDS3231M_SquareWave_1Hz);   rtc.writeSqwPinMode(eDS3231M_SquareWave_1Hz);
-  // digitalPinToInterrupt convertit le n° de broche en n° d'interruption, exemples + 
-  // Arduino UNO : interruption n°0 sur connecteur broche 2 +  // digitalPinToInterrupt convertit le n° de broche en n° d'interruption
-  // Arduino MKR Zéro : interruption n°6 sur broche 0+
   attachInterrupt(digitalPinToInterrupt(interruptPin), interrupt_handler, RISING);   attachInterrupt(digitalPinToInterrupt(interruptPin), interrupt_handler, RISING);
 } }
  • materiels/temps/htr/htri2c.1714808381.txt.gz
  • Dernière modification : 2024/05/04 09:39
  • de phil