PWM using counters or not using counters?
Mickster
Posts: 2,721
Got frustrated with the search feature...PWM is too short I guess.
Anyway, do I understand that there are two methods of generating PWM on the Prop, either straight PASM or using the counters?
Cheers!
Mickster
Anyway, do I understand that there are two methods of generating PWM on the Prop, either straight PASM or using the counters?
Cheers!
Mickster
Comments
http://forums.parallax.com/showthread.php?124861
http://forums.parallax.com/showthread.php?104121
http://forums.parallax.com/showthread.php?100276
-Phil
I have a million ideas for the Prop but don't have as much time as I'd like to hunt down some of these answers so I apologize if I appear to be taking the easy way out.
All the best,
Mickster
In the above code
pin is the where the signal will appear
H
Regards,
Mickster
A little external conditioning sounds a good idea.
You could use a small PLD, to turn Quad into Two Counter pulses, so a pair of counters manage the value.
One is Up, one is Down, and the difference is the result. Counters are inside the Prop, conditioning is external.
Practical limit in a 44 pin CPLD (sub $2) is 8 Quad Channels, and it can include an Error-Gatherer feature, which can catch any Double-edge instance, and those indicate the CLK is too slow for the Quad-Data (or noise). Just count pulses on the Error pin.
Maximum Clock speed ?
With no margins, and if we do the Count on Level=LOW (sparse edges are 1 clk =\_/= ) and assuming a 80Mhz clk is avail, and the PLD prop times are ok, I think it will (amazingly) run to 80MHz accumulate rates.
A practical system might choose a lower clock, to save power/emc ?
In that case, you would swap to edge mode on the Prop Counters.
Exactly! However, I was thinking on the lines of a simple 74xx74 (Opinion?)
Very interesting. Any recommendations on a painless way to get involved with CPLD's?
All the best,
Mickster
-Phil
If you have one cog doing all 4 encoders then you could have two cogs running the PWM and doing the PID, each cog could uses timers for two channels of PWM.
Graham
Yes, I've been around and around with these various configuration options and here's my latest reasoning:
- I don't need more than a few 10s of kHZ for PWM
- My encoder count frequency requirement could easily increase in the future (commercially available motion controllers can handle 18+MHz)
Now I'm very much a noob so maybe I misunderstand the programming possibilities so please go easy on me but here's my latest concept:- Cogs 1 - 4 dedicated to generating the PWM motor command for axes 1 - 4.
- Encoders for axes 1 - 4 feed the counters of the respective cogs (quad decode via external 74xx74)
- PWM loops grab the counter values and write to hub for use by the PID/motion profiling cog
- Cog 5 takes care of all four PID loops and motion profiles at a sample rate of 512uS (reads encoder counts from hub and writes PWM cmds to hub)
- Cog 6 pre-processes commands, checks for over-travel limits and general purpose PLC
- Cog 7 serial communications
- Cog 8 possibly serial communications or video output
I realize that there are several ways to skin this cat.Thanks for the input.
Regards,
Mickster
P.S. This is not a cost sensitive project and I will be adding a differential line receiver to take advantage of the complementary encoder outputs to help the noise immunity.
I've done simple motor control on a couple projects. In fact, just last week I coded a 3-axis camera platform that used encoders for positioning and speed control.
Attached is an object I recently ported from Spin to PASM to control two motors using the counters. There are three pins for each: pwm output, direction, and an enable pin (the chip my project uses has a motor enable, you can specify -1 in this parameter for non use). With this object you can run one or two motors; this would cut your pwm cogs requirement down by two.
That gets points for simplicity, but it only decodes one edge in four, so you need four times the precision in your sensor, for the same system resolution. Usually, that 4x jump in sensor costs much more than Silicon.
It is also self clocking, so the edges fed forward to the Prop, are async in timing & there is no minimum pulse guarantee on a noise spike, and the behavior on a common mode spike is a lottery..
The Edge Counter mode should tolerate async timing, at low enough speeds, but it cannot help the other issues.
Cheapest starters kits are the Lattice Breakout boards : [ LC4256ZE-B-EVN LCMXO2-1200ZE-B-EVN ]
If you are not cost-sensitive, the LCMXO2-1200ZE board has some serious logic capability, and those boards are cheap enough you can even drop them into a project.
Highest logic density in the low macrocell CPLDs ($1-3) are Atmel ATF750CL/ATF150x, where I use the simpler/faster CUPL for design entry.
(think ASM level code - Boolean equation entry)
CUPL can also support the smaller 16V8 & 22V10 and can create Logic Test vectors, which will work with a Device Programmer to allow real silicon testing.
(16V8 & 22V10 need special programmers, whilst ATF150x also works on JTAG : Pgmr ATDH1150USB shows $46 @ Mouser )
Lattice uses a higher level HDL entry, and timing simulation.
HDL code for that could be a challenge with the linked D,AR, but you'd tend not to use HDL on Two FF.
It is always a good idea to have margin here.
Plenty of stories from the field, where the real-world was not as nice as the back-of-an-envelope
Cog1: PID/PWM for two motors the read encoder position from cog3 and commanded position from cog3.
Cog2: PID/PWM for two more motors
Cog3: Reads 4 encoders
Cog3: Motion control, sends commands to cogs 1 and 2.
Cog4: etc etc
Graham
It still strikes me as bass-ackwards (?) I need a minimum of 1.6MHz encoder reading capability for EACH axis.
Regards,
Mickster
Looking again and considering the need for 1.6Mhz and more potentially I might do the following:
Cog 1: PWM and PID for all 4 channels, using Phil's object which can do 8 channels at 23Mhz with 8 bit resolution in one cog: http://forums.parallax.com/showthread.php?104121
Cog 2-5: Encoder reading and anything else you want them to do at the same time
Also seems not so good, an alternative would be to use a second micro for the encoders and just request current positions from it via serial at your PID loop rate (lower than PWM normally).
My concern about your idea is that on the face of it, fairly low frequency PWM sounds fine to hard code but it is not the period but the minimum on time that creates programming issues. If you take 20khz as your PWM frequency then 8-bit resolution means the minimum on time is only 15 clock cycles, so you are reaching a limit already for the resolution vs period, the counter based PWM generation can go right down to a single clock count (because it uses the counter a little like a oneshot), something you can't do with waitcnt. Phil's object is great because you get all those channels in one cog but is also limited in resolution in this way.
The other complication is that the time you have left over to process other things becomes variable and the minimum is the PWM time period/2. You would have to ensure that you do your processing in on or the off time, choosing the largest.
If you CAN combine the non hardware PWM and the PID in one cog then your idea does seem to be a good one.
Just FYI below is the expected resolution vs frequency for counter driven PWM:
Cheers,
Graham
Perfect! Thank you. This was going to be my next question. So for a PWM frequency of around 20KHz, I can expect an effective DAC resolution (filtered) of around 11bits?
This thread has been a very great help to me.
"jmg" put me on to a quad-decode chip some time ago and I see that they have one that outputs up/down counts that I could tie to the Prop's counters.
I think I will reduce the axis count and use the counters for both command and feedback.
Phil's 8-bit pwm is perfect for driving DC-coil solenoid valves, I bet.
Thank you all, once again!
Mickster
It is just a shame we cannot find a way to read an encoder with one counter (using the second pin and logic) but it seems impossible as the counter always accumulates.
Graham