Pages Menu
Categories Menu

Posted by on Aug 7, 2011 in Atmel AVR, Microcontrollers | 51 comments

AVR Timers – PWM Mode – Part I

AVR Timers – PWM Mode – Part I

AVR Series

Pulse Width Modulation (PWM) is a very common technique in telecommunication and power control. Learn how easily you can do so using AVRs! This post discusses all the necessary theoretical concepts related to PWM. Here it goes…

Welcome back! Till now, in the AVR Timers, we have discussed regarding the timer concepts, prescalers, interrupts, ctc mode, etc. Refer to the following tutorials for them.

In this tutorial, I will introduce you to another mode of AVR Timers – PWM Mode.


Let us assume that a DC motor is connected to the power supply as follows.

Motor 12V 300rpm

Motor 12V 300rpm

The motor is rated 12V/300rpm. This means that (assuming ideal conditions) the motor will run at 300 rpm only when 12V DC is supplied to it. If we apply 6V, the motor will run at only 150 rpm. For more details regarding controlling DC motor using AVR, view this. Now let us provide the following signal (12V DC) to the motor.

12V DC Supply

12V DC Supply

The motor will rotate at 300 rpm. Now let us change the voltage level as follows (6V DC).

6V DC Supply

6V DC Supply

We find that the motor rotates at 150 rpm. Now let us change the voltage level once again as follows (0V DC).

0V DC Supply

0V DC Supply

This time, unsurprisingly, the motor doesn’t run at all. Okay, so let’s make it more interesting. What if we provide the following supply to the motor.

50% Duty Cycle PWM

50% Duty Cycle PWM

Now how will the motor respond? Will it start for some time, then after some time it stops, then starts, then stops, and then starts again, and so on. Or will it get confused and simply blast? :D

Well, each and every body in this world has some inertia. Say the motor above rotates whenever it is powered on. As soon as it is powered off, it will tend to stop. But it doesn’t stop immediately, it takes some time. But before it stops completely, it is powered on again! Thus it starts to move. But even now, it takes some time to reach its full speed. But before it happens, it is powered off, and so on. Thus, the overall effect of this action is that the motor rotates continuously, but at a lower speed. In the above case, the motor will behave exactly as if a 6V DC is supplied to it, i.e. rotate at 150 rpm!

Okay, so now, let’s modify the signal as follows.

25% Duty Cycle PWM

25% Duty Cycle PWM

Now what happens? Yes! You guessed it right! (I hope so ;)) Since the on-time is less than the off-time, the effective speed of the motor reduce. In this case, the speed becomes 75 rpm (since off-time = 3 times on-time, i.e. speed = 300/4 = 75 rpm).

Now it’s your turn to say what happens in this case:

75% Duty Cycle PWM

75% Duty Cycle PWM

This is what we call Pulse Width Modulation, commonly known as PWM.

PWM – Pulse Width Modulation

PWM stands for Pulse Width Modulation. It is basically a modulation technique, in which the width of the carrier pulse is varied in accordance with the analog message signal. As described above, it is commonly used to control the power fed to an electrical device, whether it is a motor, an LED, speakers, etc.

PWM Generation

The simplest way to generate a PWM signal is by comparing the a predetermined waveform with a fixed voltage level as shown below.

Compare PWM

Compare PWM

In the diagram shown above, we have a predetermined waveform, sawtooth waveform. We compare this waveform with a fixed DC level. It has three compare output modes of operation:

  • Inverted Mode – In this mode, if the waveform value is greater than the compare level, then the output is set high, or else the output is low. This is represented in figure A above.
  • Non-Inverted Mode – In this mode, the output is high whenever the compare level is greater than the waveform level and low otherwise. This is represented in figure B above.
  • Toggle Mode – In this mode, the output toggles whenever there is a compare match. If the output is high, it becomes low, and vice-versa.

But it’s always not necessary that we have a fixed compare level. Those who have had exposure in the field of analog/digital communication must have come across cases where a sawtooth carrier wave is compared with a sinusoidal message signal as shown below.

PWM Modulation

PWM Modulation

Here you can clearly see and understand the meaning of ‘width’ in Pulse Width Modulation! ;-)

PWM can also be generated by making analog circuits like the one described here.

Duty Cycle

The Duty Cycle of a PWM Waveform is given byDuty Cycle

 This is clarified in the following diagram.

Duty Cycle Explained

Duty Cycle Explained

Timer Concepts – Revisited

In this section, we will revise some important and necessary concepts related to timers. Consider the following timer diagram.

Fixed and Variable TOP

Fixed and Variable TOP in Timers

We are very well aware that the AVR provides us with an option of 8 and 16 bit timers. 8bit timers count from 0 to 255, then back to zero and so on. 16bit timers count from 0 to 65535, then back to zero. Thus for a 8bit timer, MAX = 255 and for a 16bit timer, MAX = 65535.

The timer always counts from 0 to TOP, then overflows back to zero. In figure A shown above, TOP = MAX. Now, I guess you all are familiar with timers in CTC Mode, in which you can clear the timer whenever a compare match occurs. Due to this, the value of TOP can be reduced as shown in figure B. The yellow line shows how the timer would have gone in normal mode. Now, the CTC Mode can be extended to introduce variable TOP as shown in figure C (however there isn’t any practical utility of this).

TOP never exceeds MAX. TOP <= MAX.

Now that you are aware of the terminologies of TOP, BOTTOM and MAX, we can proceed to the different modes of operation.

PWM Modes of Operation

In general, there are three modes of operation of PWM Timers:

  • Fast PWM
  • Phase Correct PWM
  • Frequency and Phase Correct PWM

Fast PWM

Consider the following diagram.

Fast PWM

Fast PWM

In simple terms, this is Fast PWM! We have a sawtooth waveform, and we compare it with a fixed voltage level (say A), and thus we get a PWM output as shown (in A). Now suppose we increase the compare voltage level (to, say B). In this case, as we can see, the pulse width has reduced, and hence the duty cycle. But, as you can see, both the pulses (A and B) end at the same time irrespective of their starting time.

In this mode, since sawtooth waveform is used, the timer counter TCNTn (n = 0,1,2) counts from BOTTOM to TOP and then it is simply allowed to overflow (or cleared at a compare match) to BOTTOM.

Phase Correct PWM

Now have a look at the following diagram.

Phase Correct PWM

Phase Correct PWM

Here instead of a sawtooth waveform, we have used a triangular waveform. Even here, you can see how PWM is generated. We can see that upon increasing the compare voltage level, the duty cycle reduces. But unlike Fast PWM, the phase of the PWM is maintained. Thus it is called Phase Correct PWM.

By visual inspection, we can clearly see that the frequency of Fast PWM is twice that of Phase Correct PWM.

Frequency and Phase Correct PWM

Technically, Phase Correct PWM and Frequency and Phase Correct PWM are same if the TOP remains same. If we have a variable TOP, the frequency of the output wave will keep changing as shown below. The following illustration has a flaw (which one of my readers pointed out) that it basically represents a Fast PWM with variable frequency. Due to lack of availability of time, it is not possible for me to create another illustration. So, kindly bear with me. However, you can at least get the concept of variable TOP from the diagram.

Frequency and Phase Correct PWM Description

Frequency and Phase Correct PWM Description

Thus, for this, we need Frequency and Phase Correct PWM. Since in most cases the value of TOP remains same, it doesn’t matter which one we are choosing – Phase Correct or Frequency and Phase Correct PWM.

Making Choices

Now that you are familiar with all the PWM concepts, it’s upto you to decide

  • Which timer to choose?
  • Which mode of operation to choose?
  • Which compare output mode to choose?

Choosing Timer

In AVR, PWM Mode is available in all timers. TIMER0 and TIMER2 provide 8bit accuracy whereas TIMER1 provides 16bit accuracy. In 8bit accuracy, you have 256 individual steps, whereas in 16bit accuracy, you have 65536 steps.

Now suppose you want to control the speed of a DC motor. In this case, having 65536 steps is totally useless! Thus we can use an 8bit timer for this. Even 8bit is too much, but there is no other choice. Obviously there isn’t much difference in speed between 123/256th and 124/256th of full speed in case of a motor! But if you use servo motors, you have to use 16bit timer. More on that later.

If you need quite high resolution in your application, go for 16bit timer.

Choosing Mode of Operation

If you want to control the speed of DC motors or brightness of LEDs, go for any one of them. But if you are using it for telecommunication purposes, or for signal sampling, fast PWM would be better. For general applications, phase correct PWM would do.

Choosing Compare Output Modes

Out of the three modes, inverted, non-inverted and toggle mode, non-inverted mode is the most reasonable. This is because upon increasing the compare voltage, the duty cycle increases. However, you can choose any of them. Regarding toggle mode, I wonder if there is any practical application of it.

So this is it! In the next post, we will learn how to implement it in AVRs! So till then, catch up with me by subscribing to my blog or by grabbing RSS Feeds! And don’t forget to post your comments! :) Enjoy!


  1. Excellent tutorial, bro please bring part 2

  2. :) u n fb??

    • yeah..

  3. really its too good…….:)

  4. The way you explain, it is easy to understand.
    I can’t wait your next tutorial bro.

  5. Nice Tutorial with elegant diagrams.
    I think the diagram corresponding to “frequency and phase correct PWM” is wrong.

    • Oh! Thanks for pointing it out! It is now difficult for me to make another diagram. I will modify the post instead.

  6. Though commenting here, its for all…
    I found tons of tutorials on internet but this is the only place where I built up my concepts in real sense…. Thanx a lot admin :)

    My best wishes are always with u…

  7. Its one of the awesome tutorials i have ever seen. the way its explained is awesome. this is the best site for anyone to learn. hope mayank keeps this blog active by updating frequently.

  8. very much impress . . . . .

  9. nice bro . nice and thnkss:-)

  10. bro you are fantastic ! i was so confused with timers ur explanation style is awesome …

  11. Great series of tutorials! Thank you very much!

  12. You are good teacher..well done..Given importance to details.
    everybody can write about controller but not this detail. I will first to buy a book if you write one.. Thanks !! great help !!

    • Hi Vijay

      Thankx… ;-)

  13. wow ! the best ever tutorial I’ve read on web

    • Thanks a lot Saravanan! You don’t know how much that compliment means to me! :)

  14. Hello,

    Hi, I have read your timer tutorials and I appreciate very much your work here, but I don’t get one thing. You wrote that you get higher resolution with 16 bit timer than with 8 bit timer in the “choosing timer” section. Why is that? I thought that the size of timer only influences how much time you can measure, and the frequency is responsible for the resolution. I probably mix things…

    • Hello Lord Vader,

      Yes, you’re correct. If you use timers to measure time, then the size influences the time you can measure and the frequency is responsible for the resolution. But here in this article, we are dealing specifically with PWM. In case of PWM, the duty cycle is spread over the range 0-100, and the size of the timer represents individual steps within this range. This is why greater the size of timer, greater the resolution. Does that make sense? Try reading the next article to know how to make it happen.

      • now I understand it totally, thanks a lot!

  15. OMG!!! dis is too gud 4 me,, i refered text buk too,,, but didn’t get dis concept….. u had explained dis with practical examples… thank you sooo much sir!!!!!!


  1. AVR Timers – PWM Mode – Part II « maxEmbedded - [...] my previous post, we have discussed the basic concepts of PWM. Let’s summarize it [...]
  2. AVR Timers – CTC Mode « maxEmbedded - [...] all for CTC Mode. I hope you enjoyed reading it! In the next post, we will discuss the different…
  3. Introduction to AVR Timers « maxEmbedded - [...] from normal operation, these three timers can be either operated in normal mode, CTC mode or PWM mode. We…

Leave a Reply

%d bloggers like this: