Idea for motor driver, ADC PWM control loop
ManAtWork
Posts: 2,178
in Propeller 2
I have an idea for a very simple power stage to drive stepper motors. I know there are ready-to-use ICs for this but as soon as you need more than 2A current or more than 36V they either become expensive or generate a lot of heat. Discrete MOSFETs are much better. A full bridge that can handle 50V and 4A without much cooling can be built for ~$1. Two full bridges are required to drive a stepper motor with 2 windings.
Since stepper motors are operated in current mode a feedback loop is required. For my servo project I use isolated current sensors which is handy when mains voltage is used directly. For small stepper motors this is overkill and would be far too expensive. Instead, current sensor shunt resistors are used. Theese have very little reistance (33 milli ohms for example) otherwise they would heat up too much at high currents. The low signal amplitude (100mV @ 3A) requires high resolution.
To avoid the need for external amplifiers my idea was to use the higher resolution modes of the built in ADCs of the P2. Their disadvantage is that they are not suited for auto calibration. Hence, they only work well if AC coupled and the DC offset can't be compensated easily. But I'm optimistic that this can be achieved with clever software.
Typical circuits use only one shunt resistor which is shared by both legs of the full bridge. However, this would cause problems in our case because at standstill and low speed the duty cycle is very low (only a few microseconds on time) and we wouldn't have enough time to measure current precisely. With two shunt resistors we always see more than 50% duty cycle because the current also flows through the resistors during the free-wheeling phase. One resistors costs less than $0.10 so this is no big problem.
Since stepper motors are operated in current mode a feedback loop is required. For my servo project I use isolated current sensors which is handy when mains voltage is used directly. For small stepper motors this is overkill and would be far too expensive. Instead, current sensor shunt resistors are used. Theese have very little reistance (33 milli ohms for example) otherwise they would heat up too much at high currents. The low signal amplitude (100mV @ 3A) requires high resolution.
To avoid the need for external amplifiers my idea was to use the higher resolution modes of the built in ADCs of the P2. Their disadvantage is that they are not suited for auto calibration. Hence, they only work well if AC coupled and the DC offset can't be compensated easily. But I'm optimistic that this can be achieved with clever software.
Typical circuits use only one shunt resistor which is shared by both legs of the full bridge. However, this would cause problems in our case because at standstill and low speed the duty cycle is very low (only a few microseconds on time) and we wouldn't have enough time to measure current precisely. With two shunt resistors we always see more than 50% duty cycle because the current also flows through the resistors during the free-wheeling phase. One resistors costs less than $0.10 so this is no big problem.
Comments
phase 1 state A: depending on polarity either T1 and T3 or T2 and T4 are conducting, current is rising
phase 2 state B: T1 and T3 are conducting (free wheeling, lower circuit), current is falling (slow decay)
phase 3 state A: same as phase 1
phase 4 state C: T2 and T4 are conducting (free wheeling, upper circuit)
At low RPM duty cycle is low, this means phase 1 and 3 are short and phase 2 and 4 use up almost 50% of the cycle time, each.
At higher RPM there is an additional phase shift between current and voltage so that one of the phases 1 and 3 becomes a fast-decay phase where energy is transferred back to the power supply. Duty cycle increases so that phase 1 and 3 become longer and 2 and 4 shorter.
Edit: in the diagram swap the "current at R1/R2" traces. Of course, current flows through R1 when T1 is on and not when T2 is on.
At very high speeds the duty cycle saturates because motor winding inductance and back EMF limit the current. The supply voltage is no longer high enough to overcome back EMF and losses so that the currrent is decreasing. At this point (high frequency) de-modulation is no longer possible because phase 1 and 3 (with the same state A) take up 100% of the time. But now we still have an AC signal. Instead of HF modulation we see the "baseband" LF signal with lower frequency. The "corner frequency" where duty cycle saturation happens is usually around 500Hz. PWM frequency is usually in the 16 to 25kHz range. So we need to make sure that our overall bandwidth covers the range from 200Hz to at least 100kHz to have some headroom for harmonics.
I think the sample frequency should be in the 1MHz range. To get higher resolution (min 10 bit would be nice) an average of multiple samples could be used.
However, if multiple motors are to be controlled by a single P2 we have more than one single star ground point and if the motors run at different speeds the AC signal components might interfere each other (inter-modulation). I hope we could find a solution how to eliminate or at least minimize that effect.
The most critical condition is standstill or slow speed where the drives have to be as silent and accurate as possible. At higher speeds the motors are humming or whisteling anyway so a small error in amplitude won't be noticed.
As already said, at slow speeds the duty cycle is always near 50% so the de-modulation can sum up many samples per PWM period to increase resolution. An accuracy (linearity and offset) of 0.1% or better would be disirable. This would mean 5mA max. error at 5A peak motor current. Gain error doen't matter much and can be as high as 10% as long as both channels match to 1 or 2%.
https://analog.com/media/en/analog-dialogue/raqs/raq-issue-145.pdf
It's also reccomended in situations where ground potentials differ, which would help in case of multiple motors control.
Hope it helps
Henrique
And even if money didn't matter the challange here is to use as few external parts as possible. It would be very cool if the P2 could drive a stepper motor with only two MOSFET pairs, two resistors and two gate driver ICs. Everybody else could do it with special motor driver ICs or complex discrete analogue ciurquitry. But I just don't want to.
I'm also interested in current sensing the P2 current via 50 milliohm resistors but was thinking of DC rather than AC coupling (since we also have a calibration points at rails (near VIO, or near GIO for low side sensing here). There may be a way of multiplexing the current sense resistor with a pullup resistor, so current can be read when the CS pin of flash is high
The ADA4807s also come in a 4 pack, but yes probably overkill for this
That's the point of a filter like that. If you're reading some continuous signal, it's probably either going to stay roughly in the same ballpark or changing so much that the precision isn't really important. Relatedly, see DSD audio. DSD64 (as used in SACD) stores just 64 raw ADC bits in the same period taken up by one 16 bit sample in normal PCM CD audio, yet is of very slightly better quality (at a 4x size increase...).
That trait just presents as a lag when not interrupted. For a 256 bit-clock per sample, the samples are effectively 768 bit-clocks lagging the analogue input. Or probably more accurately, each sample period is three sample intervals long.
The accumulation in the Sinc3 registers is at 24 bits by then, so ENOB of 16-bit has some headroom.
If I understand correctly you want the P2 to sense its own current draw. That should be possible. But don't expect the ADC auto calibration to be perfect. There is an Offset that remains after calibration and that's pin and temperature dependent. I'd use an external multiplexer (74HC4051 are cheap) and AC coupling to get rid of the DC offset.
Using the ADC x 31.6 mode would give much better resolution and SNR. What accuracy and bandwidth do you need?
Oversampling ratio (OSR) = 256 seems to be the norm for sinc3. The "post-diff ENOB" values in the doc for sinc2 & sinc3 should be treated as "output data width" and real-life ENOBs will be less.
The latest doc I have says this about sinc2 vs sinc3:
I find "quite ideal" a bit troubling and I'd prefer the following (changes in bold):
I think "better" is more accurate and safer to put in an official document as sincX filters are not "ideal" regarding the passband, which is not flat. I don't know whether Chip will see this post.
To get best zeroing you may need a modest series R that can be shorted, or a SPST analog switch like 1G3157 allows a single component design - ADC may not need to be AC coupled, as some modest gain can be asked for if you rely on 1v8 being 150mV away from 3v3/2
Unfortunatelly, I need more than 8 pins for one motor:
* 4 PWM outputs (one for each half bridge / motor terminal)
* 4 ADC inputs
* one input for overcurrent alarm (triggered by a high side shunt to be protected against shorts to ground)
* one enable output (to disable all MOSFETs in the case of overcurrent)
The P2 has plenty of pins so it still could control up to 6 motors. But an "accessory board" style PCB that can be plugged onto an 8-pin port of the EVAL board would be cool.
With current sensors or external amplifiers we could get rid of two ADC inputs and trade pin count for external part count.
However, it's the best way to find out if it works. Then I can make a 4 axis board with all the ground connections on board.
BTW, 3 won't fit on one side of the KISS board anyway but 2 on each side.
Making a POC board is totally different than making an accessory board for the general public use.
The major threat I can see here is a user himself. It so happens these days (many) people expect an accessory board should be immune to whatever abuse the user might come up with. Nothing wrong with that in general but it often makes the design more complicated and costly to make a board "fool proof".
Both of these could be avoided if the user base was somewhat more "technically literate" and with the attitude to understand how it works before plugging it in, which is not always the case. So yes, I agree. It might be challenging to produce it as an accessory board.
Another argument against an accessory board is the fact that multiple supply voltages are neccessary. For a single motor board step-up or down converters would make it more expensive. Without converters it's not user-freindly.
It pretty much depends on how exactly the user wants to address the powering scheme. I, for one, would go with a separate (to the board, provided by the user) power supply module with all voltages needed, starting from 5V and up. That would fit the bill for me.
BTW, have you considered powerSTEP01 from ST ? It looks promising. Not cheap, true, but relatively easy to route and powerful.
The P2 feedback resistor is ~ 540k, so that's quite a long time to charge the 100nF into the measuring region.
Experimenting on the value may be needed, and capture/zero needs to be carefully PWM synchronous..
Of course, that's just a rough estimate and experiments have to be carried out to find the optimum component values.
And yes, de-modulation has to be synchronous to the PWM with at least 3 samples dead-time after switching states.
(4 layers, double sided SMD placement)
Looks good.
Do you plan to make these available for purchase at some point if the tests are successful ?
As a complete product with only the power supply, motor terminals and step&dir inputs exposed it could be safe with all kinds of overcurrent and thermal protection. But as "experimental kit" I fear it calls for trouble.
I often forget these days some people "experiment" without even the slightest clue as to what might come out of it. It is something very different to experiment with something on ones own than it is to let other people do the same and risk being held responsible for whatever consequence their careless experimentation might bring. I'd be cautious too.
Well, how did the boards come out ? Did you have a chance to populate them and do some initial testing ?
This will not be for everybody to play with if not placed inside some sort of an enclosure.
This big 220uF/63v cap - if one is not careful (I'm trying hard not to say to much)...
I had a 1000uF/10v blow up long time ago. There is still a deep mark in the ceiling.
I must say, I was extremely lucky.