Cours:InfoS2 tdGenerationSignal
Révision datée du 12 mars 2024 à 08:42 par Bjacquot (discussion | contributions) (→Configuration du timer 2 en {{Rouge|fast PWM}})
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.
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
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
Compléter en conséquence le programme avec la configuration du timer :
int main()
{
// sortie utiliser pour la synchronisation de l'oscillo
DDRB |=(1<<PB2);
// configuration de la sortie
// 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)
// afin de synchroniser, on change l'état de PB2 à chaque période
if ( OCR2B==99) PORTB^=(1<<PB2);
_delay_ms(100);
}
}