Cours:InfoS2 tdGenerationSignal

De troyesGEII
Révision datée du 12 mars 2024 à 09:38 par Bjacquot (discussion | contributions) (Configuration du timer 2 en {{Rouge|fast PWM}})
Aller à : navigation, rechercher
Atmega328pPinout.jpeg

Fiche résumé

Retour à la liste des Tds/Tps

Éléments de correction

simuler avec simulIDE

Pensez à mettre sur la 1ère ligne de votre code :
// Compiler: Avrgcc device: nomDuMicrocontroleur


fichier pour simuler avec simulIDE : infouc_TdGenerationSignal.sim1
datasheet aTmega328p


Cahier des charges

Configuration du timer 2 en fast PWM

On utilise le Timer 2 pour générer un signal MLI qui sera filtré par un filtre passe-bas passif.

Todo.jpg Chercher dans la datasheet du µcontroleur (lien ci dessus) la section décrivant ce périphérique et plus particulièrement les pages donnant la descriptions des registres

Question.jpg En utilisant les différents tableaux dans la datasheet :

  • configurer le timer 2 en mode 7 : Fast PWM avec valeur TOP = OCR2A
  • sachant que Fmli = Fcpu / (P . (OCR2A+1)) et on souhaite une fréquence de 160 kHz
    • choisir et configurer une valeur de Prédiviseur
    • choisir une valeur pour OCR2A
  • la configuration des bits COM2?? sachant que nous utilisons le mode fast PWM sur la broche OC2B


Question.jpg Compléter en conséquence le programme avec la configuration du timer :

int main()
{
  // configuration des sorties

  // timer en mode fast PWM (mode 7)

  // valeur du prediviseur

  // génération de la sortie sur OC2B par le timer

  
  while(1)
  {
    // incrémenter régulièrement le rapport cyclique (attention à la valeur max)

    _delay_ms(100);
  }
}