<font color='black' size='2' face='Arial, Helvetica, sans-serif'>
<div style="font-family:arial,helvetica;font-size:10pt;color:black">

<div id="AOLMsgPart_2_8049a92b-d99e-40f6-85c3-13154544d555">
<font size="2" face="Arial, Helvetica, sans-serif" color="black"><font size="2">Makus,<br>
<br>
Something to keep in mind. If a pulse gets generated at some count of a timer with say 1usec resolution, and an interrupt  is programmed to occur at that time you will have (should have) the ability to program the next edge (and output pulse edge) to happen at exactly some given count in the future taking care to generate counts that use same word size as timer to match timer wrap around properties, e.g.  if an interrupt is programmed to happen at 65500 on a 16 bit timer you would of course want to add value say 200 to that using 16 bit unsigned word to get correct answer to plug into timer compare register. e.g. 164 or whatever the correct answer is.  (I have done this type of thing a number of times to create arbitrary waveform that has exactly the pulse widths I wanted - at timer resolution).<br>
<br>
Oh, and on deceleration. I am talking about stopping with inclusion of your calculated deceleration ramp, not just stopping. <br>
<br>
Also, Most times I am coordinating two motors, but CNC laser patterns I cut using DC servo motors is only real proof of my competence. I guess I do vary step rates on stepper motor line following robot.<br>
<br>
One thing with step counting, as you ramp up you can ask questions like. Have I exceeded max velocity (VMAX) , if so clip to that rate. Also you can ask questions like have I crossed  total count / 2 point if so and your deceleration rate is same you can mirror your actions and end up very close to your end point at nearly zero velocity.  Of course if your run is short you many never reach VMAX before reaching midpoint. Long runs will reach VMAX then stay at that velocity for a given number of counts before reaching midpoint... <br>
<br>
All of this is just me talking. I found it very satisfying to figure this out for myself where as PID controller ideas I had to just copy others work because beyond scope of my understanding except for some of the general concepts...<br>
<br>
As for much more than 10K steps, I would think 100K steps/second would be within reason of a "fast" microcontroller, e.g. 100 MHz range commonly available with ARM based controllers these days...   Too much for 16MHz AVR I would say..<br>
<br>
How many axes are you trying to coordinate?<br>
<br>
Ron <br>
<br>
<br>
</font>
<div style="font-family:arial,helvetica;font-size:10pt;color:black">-----Original Message-----<br>

From: markus <markus@bibi.ca><br>

To: Ron Grant <deltagraph@aol.com><br>

Cc: dprglist <dprglist@lists.dprg.org><br>

Sent: Sat, Mar 24, 2018 9:50 pm<br>

Subject: Re: [Dprglist] motion profiling with stepper motors<br>

<br>

Hi Ron,<br>

<br>

that makes sense and I see the wisdom behind your approach. The problem<br>

is I need stepper frequencies way beyond 10kHz and I have multiple<br>

steppers which will have to work in concert. Basically controlling<br>

multiple axis of a CNC machine.<br>

<br>

Coming to a stop at a specific location with a set deceleration is what<br>

I'm looking for. The important part is that the "stopping" should<br>

happen in a fully controlled manner - aka. smooth. So it doesn't just<br>

matter where I end up, it also matters how I got there.<br>

<br>

I had missed your question:<br>

> > >> 1ms later we could/should set the frequency to 10Hz but that's<br>

> > >> not possible because the period of one 5Hz cycle is 200ms.  <br>

> > You mean 10ms later... right?<br>

<br>

Unfortunately I did mean 200ms - which is the crux of the problem.<br>

Issuing a single 5Hz pulse takes 200ms which means I can't set a new<br>

value before those 200ms are up.<br>

<br>

But maybe I'm overthinking the problem.<br>

Markus<br>

<br>

<br>

<br>

On Sat, 24 Mar 2018 21:24:36 -0400<br>

Ron Grant <<a href="mailto:deltagraph@aol.com" target="_blank">deltagraph@aol.com</a>> wrote:<br>

<br>

> Markus, coming to a stop at a specific point (or count) is the beauty<br>

> of the high frequency interrupt routine approach that I use. The<br>

> routine decides if it is going to take a step and in a final ramp<br>

> down it can ask if it has reached its terminal count.  If so, the<br>

> motion is done.<br>

> <br>

> In your case, might get a bit tricky. At a given update you might<br>

> have to ask the question. Where will I be next update and what I need<br>

> to do to insure the correct count? Hmm.<br>

> <br>

> In my step rate world, I can simply apply linear ramp functions to<br>

> like StepRate+=Accel at given time step and also ask questions like<br>

> have I exceeded max velocity, if so clip StepRate or have I passed<br>

> 1/2 way point to terminal count or have I reached count where I need<br>

> to start decelerating step rate to reach correct terminal count at<br>

> about correct time with final fudge near end to drop velocity to zero<br>

> when I have reached final count. <br>

> <br>

> OK, that begs the question, if you setup (or have) an interrupt<br>

> routine fire when counter generates step pulse. You could have that<br>

> routine ask, am I at the final step count. If so, don't allow anymore<br>

> steps.   This will eliminate the headache of trying to calculate<br>

> exactly what to do with your deceleration or so I say.<br>

> <br>

> Ron Grant<br>

> <br>

> <br>

>  <br>

> <br>

>  <br>

> <br>

> -----Original Message-----<br>

> From: markus <<a href="mailto:markus@bibi.ca" target="_blank">markus@bibi.ca</a>><br>

> To: Ron Grant <<a href="mailto:deltagraph@aol.com" target="_blank">deltagraph@aol.com</a>><br>

> Cc: dprglist <<a href="mailto:dprglist@lists.dprg.org" target="_blank">dprglist@lists.dprg.org</a>><br>

> Sent: Sat, Mar 24, 2018 7:40 pm<br>

> Subject: Re: [Dprglist] motion profiling with stepper motors<br>

> <br>

> Jose, Ron, thanks for your feedback those are great implementation<br>

> pointers.<br>

> <br>

> I did implement both approaches but have trouble with the wall clock<br>

> approach (update the frequency periodically regardless if the<br>

> previous update has ever been applied). Accelerating is fine the<br>

> issue is with deceleration and coming to a halt at a specific point.<br>

> <br>

> In the linear world the distance where I have to start constant<br>

> deceleration is defined by: S = V^2 / (2 * a)<br>

> <br>

>    V ... current velocity<br>

>    A ... constant deceleration<br>

> <br>

> And again this works fine as long as the update frequency is faster<br>

> than the step frequency, but once the step frequency drops below the<br>

> update frequency I can't reduce the speed fast enough (because the<br>

> timer only updates on overflow).<br>

> <br>

> What happens is that the stepper is still turning quite fast by the<br>

> time the robot reaches its target position.<br>

> <br>

> Does anybody know how the math works here?<br>

> <br>

> Any pointers appreciated, thanks,<br>

> Markus<br>

> <br>

> <br>

> <br>

> On Tue, 20 Mar 2018 16:36:02 -0400<br>

> Ron Grant <<a href="mailto:deltagraph@aol.com" target="_blank">deltagraph@aol.com</a>> wrote:<br>

> <br>

> > Markus,<br>

> > I am not a stepper expert by any means...<br>

> > <br>

> > >> 1ms later we could/should set the frequency to 10Hz but that's<br>

> > >> not possible because the period of one 5Hz cycle is 200ms.  <br>

> > You mean 10ms later... right?<br>

> > <br>

> > I think you might be having trouble due to (as you realize) trying<br>

> > to vary a speed where number of steps per update interval is very<br>

> > low (less than one in your case).<br>

> > <br>

> > Wonder if you could be helped by using micro-stepping to increase<br>

> > apparent stepper resolution? OR are you already micro-stepping? If<br>

> > not, your 5Hz cycle might become with 16X microstep 80 Hz giving you<br>

> > ability to control slower rates more gracefully even if stepper does<br>

> > not perfectly track the micro step positions  -- fancy controllers<br>

> > and encoders help do that as far as I know.<br>

> > <br>

> > Maybe there is an elegant solution to calculate just what your<br>

> > interval needs to be.<br>

> > <br>

> > My first thought would be to linearly ramp your expected pulse<br>

> > timing every 10ms then force a step if need be. That is at time<br>

> > zero you set 100 ms as the width but at update 1 (10ms later) your<br>

> > goal is 50 ms pulse width (with 5Hz/10ms accel. rate), so you force<br>

> > a step and reset timer. At update 2 your goal would be 25ms but<br>

> > only 10 ms elapsed so no intervention...<br>

> > <br>

> > Just for fun (whether right or wrong way to do things) :<br>

> > <br>

> > My preferred way to handle steppers is with a 10 KHz interrupt that<br>

> > can decide what the step frequency is going to be with 1Hz<br>

> > resolution. Grainy when step rates are very low, but seems to work<br>

> > well.  10 KHz might be too much for slower clock speed / 8 bit MCU,<br>

> > not using any fancy timer stuff (just periodic interrupt)<br>

> > <br>

> > code for part of 10KHz interrupt routine - for left motor below<br>

> > Note TimeL is 32 bit int<br>

> > <br>

> > using step and direction driver, e.g. something like DRV8825 <br>

> > not show is update that calculated StepRateL(and R) for differential<br>

> > drive robot at say 100 Hz.<br>

> > <br>

> > TimeL += abs(StepRateL);<br>

> >  if (TimeL>10000) <br>

> >  {<br>

> >     TimeL -= 10000;<br>

> >     StepMotorDirL = (StepRateL>0);     // set DIR pin     REVERSE L<br>

> >      if (StepRateL<0) MotorL--;  else MotorL++;   // virtual encoder<br>

> > count (volatile long int) StepMotorStepL =<br>

> > 1;                                      // manually generate a step<br>

> > pulse wait_us(4); StepMotorStepL = 0;   <br>

> >  }<br>

> > <br>

> > Of course you could use a timer to implement step rate, but take<br>

> > care in adjusting rates where you might shorten an interval to a<br>

> > count that the counter is beyond...  <br>

> > <br>

> > Ron Grant<br>

> > <br>

> >  <br>

> > <br>

> > -----Original Message-----<br>

> > From: markus <<a href="mailto:markus@bibi.ca" target="_blank">markus@bibi.ca</a>><br>

> > To: DPRG <<a href="mailto:dprglist@lists.dprg.org" target="_blank">dprglist@lists.dprg.org</a>><br>

> > Sent: Tue, Mar 20, 2018 12:53 pm<br>

> > Subject: [Dprglist] motion profiling with stepper motors<br>

> > <br>

> > I started playing around with motion profiling and thought using a<br>

> > stepper was easier for experimenting. I've implemented "constant<br>

> > acceleration" and started to wonder what the correct implementation<br>

> > is when the stepper frequency is below the update frequency.<br>

> > <br>

> > Let's say motion profiling updates the frequency every 10ms and the<br>

> > acceleration limit is set to 5Hz/10ms. So at the initial update the<br>

> > frequency is set to 5Hz - 1ms later we could/should set the<br>

> > frequency to 10Hz but that's not possible because the period of one<br>

> > 5Hz cycle is 200ms.<br>

> > <br>

> > So the question I have is what is the correct value to update the<br>

> > timer at the end of those 200ms?<br>

> >  -  10Hz<br>

> >  - 100Hz<br>

> > <br>

> > Both seem wrong, if I set it to 10Hz it's not really "constant<br>

> > accelleration" at low speeds from a wall clock perspective. And if I<br>

> > set it to 100Hz I might exceed the "constant accelleration" from the<br>

> > motors perspective.<br>

> > <br>

> > Comments, thoughts?<br>

> > Markus<br>

> > _______________________________________________<br>

> > DPRGlist mailing list<br>

> > <a href="mailto:DPRGlist@lists.dprg.org" target="_blank">DPRGlist@lists.dprg.org</a><br>

> > <a href="http://lists.dprg.org/listinfo.cgi/dprglist-dprg.org" target="_blank">http://lists.dprg.org/listinfo.cgi/dprglist-dprg.org</a><br>

> > <br>

> > <br>

> <br>

> <br>

<br>

</div>

</font>
</div>

</div>
</font>